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Zilog offers microprocessors in 
every form: from components and 
development systems to board- 
level products and complete 
general-purpose microcomputer 
systems. This edition of the Zilog 
Data Book describes Zilog com- 
ponents, development systems, 
and microcomputer boards. You'll 
also find a section on the in-depth 
training courses now offered for 
most Zilog products. 


Zilog components, the basic 


building blocks for our other 
microcomputer products, include 
the 8-bit Z80® Microprocessor 
and its family of intelligent 


Microcomputers in Every Form 


peripherals, the Z8™ Family of 
Single-Chip Microcomputers, and 
the 16-bit Z8000™ Micro- 
processor and its family of in- 
telligent peripherals. 


New produc~s introduced in 
this data book are the Z800™ 
Family of Microprocessors, which 
continues the Z80® tradition, and 
the Z80,OOOTM Microprocessor, 
which establishes Zilog's 
supremacy in the 32-bit market. 
Also new is the Z8070 APU 
Arithmetic ProceSSing Unit for the 
Z800, Z8000, and Z80,OOO 
microprocessor families. 
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Zilog offers a wide variety of . 


development environments, rang- 
ing from the inexpensive Z8 and 
Z8000 Development Modules to 
the more elaborate EMS 8000 
Development ·System. 
Also offered are Models 11, 21, 
and 31 of the System 8000 high- 
performance, time-sharing com· 
puter system. In addition, EMS 
8000 and Z-SCAN 8000 both pro- 
vide in-circuit emulation for the 
Z8000 Family of Microprocessors, 
and Z-SCAN 800 provides in- 
circuit emUlation for the Z800 
Family. 
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Pioneering the 
Microworld 


Zilog remains an industry 


leader, thanks to continuing in- 
novation in microcomputer con- 
cepts and integrated design as 
exemplified in the Z80 Family 
microcomputer products. 
At Zilog, innovation means 
using proven, sophisticated main- 
frame and minicomputer con- 
cepts and translating them into 
the latest LSI technologies. In- 
tegration means more than 
designing an ever-greater number 
of functions onto 
a single chip. Zilog integrates 
technologies-LSI design 
enhanced by advances in 
computer-based system archi- 
tecture and system design 
technologies. 
Zilog offers microprocessor 


solutions to computing problems: 
from components and develop- 
ment systems to OEM board-level 
products and general-purpose 
microcomputer systems. 
This guide to the Z80 Family of 
state-of-the-art microprocessors 
and intelligent peripheral con- 
trollers demonstrates Zilog's con- 
tinued support for the Z80 
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microprocessor and the other 
members of the Z80 product 
family-a family first introduced 
in 1976 that continues to enjoy 
growing customer support while 
family chips are upgraded to 
newer and ever-higher standards. 
The Za400 zao CPU Central 


Processing Unit rapidly 
established itself as the most 
sophisticated, most powerful, and 
most versatile 8-bit 
microprocessor in the world. It 
offers many more features and 
functions than its competitor. 


In addition to being source- 
code compatible with the 8080A 
microprocessor, the Z80 offers 
more instructions than the.8080A 
(158 vs. 78) and numerous other 
features that simplify hardware 
requirements and reduce pro- 
gramming effort while increasing 
throughput. The dual-register set 
of the Z80 CPU allows high-speed 
context switching and more effi- 
cient interrupt processing. Two 
index registers give additional 
memory-addressing flexibility and 
simplify the task of programming. 


&H!iii¥ 


Interfacing to dynamic memory is 
simplified by on-chip, program- 
mable refresh logic. ~Iock moves 
plus string- and bit-manipulation 
instructions reduce programming 
effort, program size, and execu- 
tion time. 
The new Z80l low·Power 
Family widens the. range of 
possible Z80 applications. Pro- 
ducts in this family retain all the 
functions of the standard com- 
ponents while providing dramatic 
power savings and increased 
reliability. Available now in low- 
. power versions are the Z80 CPU, 
Z80 CTC, Z80 Pia, and Z80 SIO. 


The four traditional functions of 
a microcomputer system (parallel 
I/O, serial I/O, counting/timing, 
and direct memory access) are 
easily implemented by the Z80 
CPU and the following well- 
proven family of Z80 peripheral 
devices: Z80 Pia, Z80 SIO, Z80 
DART, Z80 CTC, and Z80 DMA. 


3 


The easily programmed, dual- 
channel Za420 zao PIO Parallel 
Input/Output Controller offers 
two 8-bit I/O ports with individual 
. handshake and pattern recogni- 
tion logic. Both I/O ports operate 
in either a byte or a bit mode. In 
addition, this device can be pro- 
grammed to generate interrupts 
for various status conditions. 


All common data communica- 
tions protocols, asynchronous 
as well as synchronous, are 
remarkably well handled by the 
Za440 zao 510 Serial Input/Out· 
put Controller. This dual-channel 


4 


receiver/transmitter device offers 
on-chip parity and CRC genera- 
tion/checking. FIFO buffering and 
flag- and frame-detection genera- 
tion logic are also offered. 


If asynchronous-only applica- 


tions are required, the cost- 
effective Za470 zao DART Dual 
Asynchronous Receiverl 
Transmitter can be used in place 
of the Z80 SID. The Z80 DART 
offers all Z80 SID asynchronous 
features in two channels. 


Timing and event-counting 
functions are the forte of the 
Za430 zao CTC Counter/Timer 
Controller. The CTC provides 


four counters, each with in- 
dividually programmable 
prescalers. The CTC is a conve- 
nient source of programmable 
clock rates for the SID . 
With the Za410 zao DMA 
Direct Memory Access Con· 
troller, data can be transferred 
directly between any two ports 
(typically, I/O and memory). The 
DMA transfers, searches, or 
search/transfers date in. Byte-by- 
Byte, Burst, or Continuous modes. 
This device can achieve an im- 
pressive 2M bits per second data 
rate in the Search mode. 


Zilog 


Features 
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• The instruction set contains 158 instructions. 
The 78 instructions of the 8080A are 
included as a subset; 8080A software com- 
patibility is maintained. 


• Eight MHz, 6 MHz, 4 MHz and 2.5 MHz 
clocks for the Z80H, Z80B, Z80A, and Z80 
CPU result in rapid instruction execution 
with consequent high data throughput. 


11 The extensive instruction set includes string, 
bit, byte, and word operations. Block 
searches and block transfers together with 
indexed and relative addreSSing result in 
the most powerful data handling capabilities 
in the microcomputer industry. 


II The Z80 microprocessors and associated 
family of peripheral controllers are linked 
by a vectored interrupt system. This system 
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may be daisy-chained to allow implementa- 
tion of a priority interrupt scheme. Little, if 
any, additional logic is required for daisy- 
chaining. 


II Duplicate sets of both general-purpose and 
flag registers are provided, easing the 
design and operation of system software 
through single-context switching, back- 
ground-foreground programming, and 
single-level interrupt processing. In addi- 
tion, two 16-bit index registers facilitate pro- 
gram processing of tables and arrays. 


III There are three modes of high-speed inter- 
rupt processing: 8080 similar, non-Z80 
peripheral device, and Z80 Family 
peripheral with or without daisy chain. 


• On-chip dynamic memory refresh counter. 
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Description 
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The Z80, Z80A, 280B, and Z80H CPUs are 
third-generation single-chip microprocessors 
with exceptional computational power. They 
offer higher system throughput and more effi- 
cient memory utilization than comparable 
second-and third-generation microprocessors. 
The internal registers contain 208 bits of 
read/write memory that are accessible to the 
programmer. These registers include two sets 
of six general-purpose registers which may be 
used individually as either 8-bit registers or as 
16-bit register pairs. In addition, there are two 
sets of accumulator and flag registers. A group 
of "Exchange" instructions makes either set of 
main or alternate registers accessible to the 
programm'er. The alternate set allows operation 
in foreground-background mode or it may be 


+5V -+- 


GND -+- 


CLOCK .... 


reserved for very fast interrupt response. 
The Z80 also contains a Stack POinter, Pro- 


gram Counter, two index registers, a Refresh 
register (counter), and an Interrupt register. 
The CPU is easy to incorporate into a system 
since it requires only a single + 5 V power 
source. All output signals are fully decoded 
and timed to control standard memory or 
peripheral Circuits, and it is supported by an 
extensive family of peripheral controllers. The 
internal block diagram (Figure 3) shows the 
primary functions of the Z80 processors. 
Subsequent text provides more detail on the 
Z80 I/O controller family, registers, instruction 
set, interrupts and daisy chaining, and CPU 
timing. 


Figure 3. zao CPU Block Diagram 


2001-0212 


Z8D Micro- 
processor 
Family 


Z8D CPU 
Registers 


2001·0213 


The Zilog Z80 microprocessor is the central 
element of a comprehensive microprocessor 
product family. This family works together in 
most applications with minimum requirements 
for additional logic, facilitating the design of 
efficient and cost-effective microcomputer- 
based systems. 


Zilog has designed five components to pro- 
vide extensive support for the Z80 micro- 
processor. These are: 


EJ The PIO (Parallel Input/Output) operates in 
both data-byte I/O transfer mode (with 
handshaking) and in bit mode (without 
handshaking). The PIO may be configured 
to interface with standard parallel 
peripheral devices such a.s printers, tape 
punches, and keyboards. 


lJ The CTC (Counter/Timer Circuit) features 
four programmable 8-bit counter/timers, 


Figure 4 shows three groups of registers 
within the Z80 CPU. The first group consists of 
duplicate sets of 8-bit registers: a prinCipal set 
and an alternate set (designated by I [primEd, 
e.g., A'). Both sets consist of the Accumula- 
tor Register, the Flag Register, and six 
general-purpose registers. Transfer of data 
between these duplicate sets of registers is 
accomplished by use of "Exchange" instruc- 
tions. The result is faster response to interrupts 
and easy, efficient implementation of such ver- 
satile programming techniques as background- 


MAIN REGISTER SET 


A 
ACCUMULATOR 
F FLAG REGISTER 


B 
GENERAL PURPOSE 
C 
GENERAL PURPOSE 


0 
GENERAL PURPOSE 
E GENERAL PURPOSE 


H 
GENERAL PURPOSE 
L 
GENERAL PURPOSE 


_SBITS---. 


_-------16 
BITS -------_ 


IX INDEX REGISTER 


IY INDEX REGISTER 


SP STACK POINTER 


PC PROGRAM COUNTER 


I INTERRUPT VECTOR I 


R MEMORY REFRESH 


_SBITS---. 


A' 


B' 


0' 


H' 


each of which has an 8-bit prescaler. Each 
of the four channels may be configured to 
operate in either counter or timer mode. 


CJ The DMA (Direct Memory Access) con- 
troller provides dual port data transfer 
operations and the ability to terminate data 
transfer as a result of a pattern match. 


IJ The SIO (Serial Input/Output) controller 
offers two channels. It is capable of 
operating in a variety of programmable 
modes for both synchronous and asyn- 
chronous communication, including 
Bi-Sync and SDLC. 


[] The DART (Dual Asynchronous Receiver/ 
Transmitter) device provides low cost 
asynchronous serial communication. It has 
two channels and a full modem control 
interface. 


foreground data processing. The second set of 
registers consists of six registers with assigned 
functions. These are ·the I (Interrupt Register), 
the R (Refresh Register), the IX and IY (Index 
Registers), the SP (Stack Pointer), and the PC 
(Program Counter). The third group consists of 
two interrupt status flip-flops, plus an addi- 
tional pair of flip-flops which assists in identi- 
fying the interrupt mode at any particular 
time. Table 1 provides further information on 
these registers. 


ALTERNATE REGISTER SET 


ACCUMULATOR 
F' 
FLAG REGISTER 


GENERAL PURPOSE 
C' 
GENERAL PURPOSE 


GENERAL PURPOSE 
E' 
GENERAL PURPOSE 


GENERAL PURPOSE 
L' 
GENERAL PURPOSE 


INTERRUPT FLlP·FLOPS 
STATUS 
B 
G---. 
~ 
INTERRUPTS DISABLED 
STORES IFF1 
4 
~ : 
INTERRUPTS ENABLED 
DURING NMI 
SERVICE 


INTERRUPT MODE FLlp·FLOPS 


IMFa 
IMFb 


INTERRUPT MODE 0 
NOT USED 
INTERRUPT MODE 1 
INTERRUPT MODE 2 


Figure 4. CPU Registers 
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Interrupts: 
General 
Operation 
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Register 


A, A' 
Accumulator 


F, F' 
. Flags 


B, B' 
General Purpose 


C, C' 
General Purpose 


D, D' 
General Purpose 


E, E' 
General Purpose 


H, H' 
General Purpose 


L, L' 
General Purpose 


Interrupt Register 


R 
Refresh Register 


IX 
Index Register 


IY 
Index Register 


SP 
Stack Pointer 


PC 
Program Counter 


IFF1-IFF2 
Interrupt Enable 


IMFa-IMFb 
Interrupt Mode 


Size (Bits) 


8 


8 


8 


8 


8 


8 


8 


8 


8 


8 


16 


16 


16 


16 


Flip-Flops 


Flip-Flops 


Remarks 


Stores an operand or the results of an operation. 


See Instruction Set. 


Can be used separately or as a 16-bit register with C. 


See B, above. 


Can be used separately or as a 16-bit register with E. 


See D, above. 


Can be used separately or as a 16-bit register with L. 


See H, above. 


Note: The (B,C), (D,E), and (H,L) sets are combined as follows: 
B - 
High byte C - 
Low byte 
D - 
High byte E - 
Low byte 
H - 
High byte L - 
Low byte 


Stores upper eight bits of memory address for vectored interrupt 
processing. 


Provides user-transparent dynamic memory refresh. Lower seven 
bits are automatically incremented and all eight are placed on 
the address bus during each instruction fetch cycle refresh time; 


U sed for indexed addressing. 


Same as IX, above. 


Holds address of the top of the stack. See Push or Pop in instruc- 
tion set. 


Holds address of next instruction. 


Set or reset to £ndicate inte'rrupt status (see Figure 4). 


Reflect Interrupt mode (see Figure 4). 


Table 1. zao CPU Registers 


The CPU accepts two interrupt input signals: 
NMI and INT. The NMI is a non-maskable 
interrupt and has the highest priority. INT is a 
lower priority interrupt and it.requires that 
interrupts be enabled in software in order to 
operate. INT can be connected to multiple 
peripheral devices in a wired-OR configura- 
tion. 
The Z80 has a single response mode for 
interrupt service for the non-maskable inter- 
rupt. The maskable interrupt, INT, has three 
programmable response modes available. 
These are: 


!II Mode a - 
similar to the 8080 micro- 
processor. 


II Mode 1 - 
Peripheral Interrupt service, for 
use with non-8080/Z80 systems. 


• Mode 2 - 
a vectored interrupt scheme, 
usually daisy-chained, for use with Z80 
Family and compatible peripheral devices. 


The CPU services interrupts by sampling the 
NMI and INT signals at the rising edge of the 
last clock of an instruction. Further interrupt 
service processing depends upon the type of 
interrupt that was detected. Details on inter- 
rupt responses are shown in the CPU Timing 
Section. 


Interrupts: 
General 
Operation 
(Continued) 


Non-Maskable Interrupt (NMI). The non- 
maskable interrupt cannot be disabled by pro- 
gram control and therefore will be accepted at 
all times by the CPU. NMI is usually 
reserved for servicing only the highest priority 
type interrupts, such as that for orderly shut- 
down after power failure has been detected. 
After recognifion of the NMI signal (providing 
BUSREQ is not active), the CPU jumps to 
restart location 0066H. Normally, software 
starting at this address contains the interrupt 
service routing. 


Maskable Interrupt (INT). Regardless of the 
interrupt mode set by the user, the 280 
response to a maskable interrupt input follows 
a common timing cycle. After the interrupt has 
been detected by the CPU (provided that 
interrupts are enabled and BUSREQ is not 
active) a special interrupt processing cycle 
begins. This is a special fetch (MI) cycle in 
which IORQ becomes active rather than 
MREQ, as in normal MI cycle. In addition, this 
special MI cycle is automatically extended by 
two WAIT states, to allow for the time required 
to acknowledge the interrupt request. 


Mode 0 Interrupt Operation. This mode is 
similar to the 8080 microprocessor interrupt 
service procedures. The interrupting device 
places an instruction on the data bus. This is 
normally a Restart instruction, which will initi- 
ate a call to the selected one of eight restart 
locations in page zero of memory. Unlike the 
8080, the 280 CPU responds to the Call in- 
struction with only one interrupt acknowledge 
cycle followed by two memory read cycles. 


Mode I Interrupt Operation. Mode 1 oper- 
ation is very similar to that for the NMI. The 
principal difference is that the Mode I inter- 
rupt has a restart location of 0038H only. 


Mode 2 Interrupt Operation. This interrupt 
mode has been designed to utilize most effec- 
tively the capabilities of the 280 microproc- 
essor and its associated peripheral family. The 
interrupting peripheral device selects the 
starting address of the interrupt service 
routine. It does this by placing an 8-bit vector 
on the data bus during the interrupt acknowl- 
edge cycle. The CPU forms a pointer using 
this byte as the lower 8-bits and the contents of 
the I register as the upper 8-bits. This points to 
an entry in a table of addresses for interrupt 
service routines. The CPU then jumps to the 
routine at that address. This flexibility in 
selecting the interrupt service routine address 


allows the peripheral device to use several dif- 
ferent types of service routines. These routines 
may be located at any available location in 
memory. Since the interrupting device sup- 
plies the low-order byte of the 2-byte vector, 
bit 0 (Ao) must be a zero. 


Interrupt Priority (Daisy Chaining and 
Nested Interrupts). The interrupt priority of 
each peripheral device is determined by its 
physical location within a daisy-chain config- 
uration. Each device in the chain has an inter- 
rupt enable input line (IEI) and an interrupt 
enable output line (lEO), which is fed to the 
next lower priority device. The first device in 
the daisy chain has its IEI input hardwired to a 
High level. The first device has highest 
priority, while each succeeding device hasa 
corresponding lower priority. This arrange- 
ment permits the CPU to select the highest 
priority interrupt from several simultaneously 
interrupting peripherals. 
The interrupting device disables its IEO line 
to the next lower priority peripheral until it has 
been serviced. After servicing, its IEO line is 
raised, allowing lower priority peripherals to 
demand interrupt servicing. 
The 280 CPU will nest (queue) any pending 
interrupts or interrupts received while a 
selected peripheral is being serviced. 


Interrupt Enable/Disable Operation. Two 
flip-flops, IFFI and 1FF2, referred to in the 
register description are used to signal the CPU 
interrupt status. Operation of the two flip-flops 
is described in Table 2. For more details, refer 
to the Z80 CPU Technical Manual and Z80 
Assembly Language Manual. 


Action 
IFFl 
IFF2 
Comments 


CPU Reset 


DI instruction 
execution 


EI instruction 
execution 


LD A,I instruction 
execution 


LD A,R instruction 
execution 


Accept NMI 


RETN instruction 
execution 


o 
o 


o 
o 


Maskable int~rrupt 
INT disabled 


Maskable interrupt 
INT disabled 


Maskable interrupt 
INT enabled 


IFF2 - 
Parity flag 


IFF2 - 
Parity flag 


o 
IFFl 
IFFl - 
IFF2 
(Maskable inter- 
rupt INT disabled) 


IFF2 
IFF2 - 
IFF} at 
completion of an 
NMI service 
routine. 


Table 2. State of Flip-Flops 
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Instruction 
Set 


8-Bit 
Load 
Group 


10 


The Z80 microprocessor has one of the most 
powerful and versatile instruction sets 
available in any 8-bit microprocessor. It 
includes such unique operations as a block 
move for fast, efficient data transfers within 
memory or between memory and I/O. It also 
allows operations on any bit in any location in 
memory. 
The folloWing is a summary of the Z80 


instruction set and shows the assembly 
language mnemonic, the operation, the flag 
status, and gives comments on each instruc- 
tion. The Z80 CPU Technical Manual 
(03-0029-01) and Assembly Language 
Programming Manual (03-0002-01) contain 
significantly more details for programming 
use. 
The instructions are divided into the 
following categories: 
o 8-bit loads 
o 16-bit loads 
o Exchanges, block transfers, and searches 
o 8-bit arithmetic and logic operations 
o General-purpose arithmetic and CPU 


control 


Symbolic 
Flags 


Mnemonic 
Operation 
S 
Z 
H 


LD r, r' 
r - 
r' 
X · 
LD r, n 
X 


LD r, (HL) 
r - 
(HL) 
X · 
LD r, (IX+d) 
r - 
(IX+d) 
X · 


LD r, (IY +d) 
r - 
(IY +d) 
X · 


LD (HL). r 
(HL) - 
r 
. X · 
LD (IX + d). r 
(IX+d) - 
r 
X · 


LD (IY +d). r 
(IY+d) - 
r 
X · 


LD (HL). n 
(HL) - 
n 
X · 


LD (IX+d). n 
(IX+d) -'n 
. X · 


LD (IY +d). n 
(IY+d) - 
n 
X · 


LD A, (BC) 
A - 
(BC) 
X · 
LD A, (DE) 
A - 
(DE) 
X · 
LD A, (nn) 
A - 
(nn) 
X · 


LD (BC). A 
(BC) - 
A 
X · 
LD (DE). A 
(DE) - 
A 
X · 
LD (nn). A 
(nn) - 
A 
X · 


LDA, I 
A - 
I 
X 


LDA, R 
A-R 
X 
0 


LD I, A 
I - 
A 
X · 


LDR, A 
R-A 
X · 


NOTES: r, r' means any of the regJSters A, E, C, D, E, H, L. 
IFF the content of the interrupt enable flip, flop, (IFF) is 
copied into the PlY flag, 
For dn explanation of !lag notation and symbols for 
mnemonic tables, see Symbolic Notation section 
following tables, 


X 
X 


X 
X 


X 


X 
X 


X 


X 


X 


X 


X 
X 
X 


X 
X 
X 


X 


X 


X 


X 


P/V 
· · · 
· 
· · 
· 


· 


· 


IFF 


IFF 


· 


N 


0 


0 


C 


o 16-bit arithmetic operations 
o Rotates and shifts 
o Bit set, reset, and test operations 
o Jumps 
o Calls, returns, and restarts 
o Input and output operations 


A variety of addreSSing modes are 
implemented to permit efficient and fast data 
transfer between various registers, memory 
locations, and input/output devices. These 
addressing modes include: 
o Immediate 
o Immediate extended 
o Modified page zero 
o Relative 
o Extended 


'0 Indexed 
o Register 
o Register indirect 
o Ifl!.plied 
o Bit 


Opcode 
No.ol No.ol M No.ol T 
76 5'3 210 Hex Byte. 
Cycles State. 


01 
r 
r' 


00 
r 
110 
-n- 


01 
r 
110 
7 


II 011 101 
DD 
19 


01 
r 
101 
-d- 
II III 101 
FD 
19 


01 
r 
110 
-d- 


Ol 110 
r 
7 
II 011 101 
DD 
19 


01 110 
r 
-d- 
II III 101 
FD 
19 


01 110 
r 
-d- 


00 110 110 
36 
10 


-n- 
II 011 101 
DD 
19 


00 110 110 
36 
-d- 
-n- 
II III 101 
FD 
19 


00 110 110 
36 
-d- 


00 001 010 
OA 
7 


00 011 010 
IA 
7 


00 III 010 
3A 
13 


-n- 


00 000 010 
02 
7 


00 010 010 
12 
7 


00 110 010 
32 
13 


-n- 
II 101 101 
ED 


01 010 III 
57 
II 101 101 
ED 


01 011 III 
5F 


II 101 101 
ED 


01 000 III 
47 
II 101 101 
ED 


01 001 III 
4F 


Comment. 


~ 
000 
B 


001 
C 


010 
D 
011 
E 


100 
H 
101 
L 
III 
A 
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IS-Bit Load 
Symbolic 
Flag. 
No.of No.of M No.of T 
Group 
Mnemonic 
Operation 
S 
Z 
H 
P/V N 
C 
76 543 210 Hex Byte. 
Cycle. State. 
Comment. 


LD dd, nn 
dd - 
nn 
X 
X 
00 ddO 001 
10 
dd 
Pair 
~ 
-n- 
01 
DE 
LD IX, nn 
IX - 
nn 
X 
X 
11 011 101 DD 
14 
10 
HL 


00 100 001 21 
11 
SP 


LD IY, nn 
IY - 
nn 
X 
X 
11 III 101 FD 
14 


00 100 001 21 


-n- 
LD HL, (nn) 
H - 
(nn+l) 
X 
X 
00 101 010 2A 
16 
L '- (nn) 
-n- 
LD dd, (nn) 
ddH - 
(nn+l) 
X 
X 
II 101 101 ED 
20 


ddL - 
(nn) 
01 ddl Oil 


-n- 
LD IX, (nn) 
IXH - 
(nn+ I) 
X 
X 
II Oil 101 DD 
20 


IXL - 
(nn) 
00 101 010 2A 


LD IY, (nn) 
IYH - 
(nn+ I) 
X 
X 
11 III 101 FD 
20 
IYL - 
(nn) 
00 101 010 2A 


-n- 
§ 


LD (nnl. HL 
(nn+l) - 
H 
X 
X 
00 100 010 22 
16 
(nn) - 
L 
-n- 
LD (nn), dd 
(nn+l) - 
ddH 
X 
X 
II 101 101 ED 
20 
8 


(nn) - 
ddL 
01 ddO Oil 
~ 
~ 
-n- 
LD (nnl. IX 
(nn+I)-IXH 
X 
X 
II 011 101 'DD 
20 


(nn) - 
IXL 
00 100 010 22 


-·n - 


LD (nn), IY 
(nn+l) - 
IYH 
X 
X 
II III 101 FD 
20 


(nn) - 
IYL 
00 100 010 22 
-n- 
LD SP, HL 
SP - 
HL 
X 
X 
II III 001 F9 
6 
LD SP, IX 
SP - 
IX 
X 
X 
II 011 101 DD 
10 
11 111 001 F9 
LD SP, IY 
SP - 
IY 
X 
X 
11 III 101 FD 
10 
II 111 001 F9 
qq 
Pair 
PUSH qq 
(SP-2) - 
qqL 
X 
X 
II qqO 101 
II 
00 
BC 


(SP-I) - 
qqH 
01 
DE 


SP - 
SP -2 
10 
HL 


PUSH IX 
(SP-2) - 
IXL 
X 
X 
II Oil 101 DD 
IS 
II 
AF 


(SP-I) - 
IXH 
II 100 101 E5 


SP - 
SP -2 


PUSH IY 
(SP-2) - 
IYL 
X 
X 
11 III 101 FD 
IS 


(SP-I) - 
IYH 
II 100 101 E5 


SP - 
SP -2 


POPqq 
qqH - 
(SP+I) 
X 
X 
II qqO 001 
10 


qqL - 
(SP) 
SP - 
SP +2 


POP IX 
IXH - 
(SP+I) 
X 
X 
II 011 101 DD 
14 
IXL - 
(SP) 
II 100 001 EI 


SP - 
SP +2 


POPIY 
IYH - 
(SP+I) 
X 
X 
II III 101 FD 
14 


IYL - 
(SP) 
II 100 001 EI 


SP - 
SP +2 


NOTES: 
dd is any 01 the register pairs BC, DE, HL, SP. 
qq is any 01 the register pairs AF, BC, DE, HL. 
(PAIR1H, (PAIR)L reler to high order and low order eight bits 01 the register pair respectively, 


e.g., BCL = C, AFH = A. 


Exchange. 
EX DE, HL 
DE - 
HL 
X 
X 
II 101 011 EB 
Block 
EX AF, AF' 
AF - 
AF' 
X 
X 
00 001 000 08 


EXX 
BC - 
BC' 
X 
X 
II Oil 001 D9 
Register bank and 
Transfer. 
DE - 
DE' 
auxiliary register 
Block Search 
HL - 
HL' 
bank exchange 
EX (SP), HL 
H - 
(SP+l) 
X 
X 
II 100 011 E3 
19 
Groups 
L - 
(SP) 


EX (SPl. IX 
IXH - 
(SP+I) 
X 
X 
11 Oil 101 DD 
23 
IXL - 
(SP) 
11 100 011 E3 
EX (SP), IY 
IYH - 
(SP+I) 
X 
X 
II III 101 FD 
23 


Iyt - 
(SP) 
CD 


II 100 011 E3 


LDI 
(DE) - 
(HL) 
X 
0 
X 
11 101 101 ED 
16 
Load (HL) into 
DE - 
DE+I 
10 100 000 AO 
(DE), increment 
HL - 
HL+I 
the pointers and 
BC - BC-I 
CD 


decrement the byte 
counter (BC) 
LDIR 
(DE) - 
(HL) 
X 
0 
X 
II 101 101 ED 
21 
!fBC * 0 


DE - 
DE+I 
10 110 000 BO 
16 
!f BC =0 


HL - 
HL+I 
BC - BC-I 
Repeat until 
BC = 0 


NOTE: CD PlY flag is 0 il the result oi BC - 1 = 0, otherwise P/V = 1. 


2001-001 
11 


Exchange. 
Symbolic 
Flags 
Opcode 
No.of No.of M No.of T 
Block 
Mnemonic 
Operallon 
S 
Z 
H 
P/V N 
C 
76 5'3 210 Hex Byte. 
Cycle. States 
Comments 
Transfer. 
CD 


Block Search 
LDD 
(DE) - 
(HL) 
X 
0 
X 
II 101 101 ED 
16 


Croups 


DE - DE-I 
lO lOl 000 A8 
HL - HL-I 
(Continued) 
BC - BC-I 
Q) 


LDDR 
(DE) - (HL) 
X 
0 
X 
II 101 lOl ED 
21 
IfBC * 0 


DE - DE-I 
lO III 000 B8 
16 
If BC = 0 


HL - HL-I 
BC - BC-I 
Repeat until 
BC = 0 
@ 
(j) 
CPI 
A - (HL) 
X 
X 
11'101 lOl ED 
16 
HL - HL+ I 
lO 100 001 Al 


BC - BC-I 
@ 
CD 
CPIR 
A - (EL) 
X 
X 
II 101 lOl ED 
21 
IfBC*Oand 
A", (HL) 
HL - HL+I 
10 110001 BI 
16 
If BC = 0 or 


BC - BC-I 
A = (HL) 
Repeat until 
A = (HL) or 
BC = 0 
~ 
CD 
CPD 
A - (EL) 
X 
X 
1 
II lOl 101 ED 
16 
HL - HL-I 
lO lOl 001 A9 


BC - BC-I 
G> 
CD 
CPDR 
A - (HL) 
X 
X 
II 101 101 ED 
21 
IfBC",Oand 
A", (HL) 
HL - HL-l 
10 III 001 B9 
16 
If BC = 0 or 


BC - BC-I 
A = (HL) 
Repeat until 
A = (HL) or 
BC = 0 


'NOTES: (j) PlY flag IS 0 if the result of Be - I = O. otherwise PlY = I. 


ev PlY flag IS 0 ot completion of instruction only. 
G) Z flag is I if A = (HL). otherwise Z = O. 


a-Bit 
ADDA. r 
A - A + r 
X 
X 'V 
10~ r 
~ 
.Arithmetic 
ADDA. n 
A-A+n 
X 
X 
V 
II ruiQJ llO 
000 B 
and Logical 
001 
C 
010 D 
Group 
ADD A. (EL) 
A - A + (HL) 
X 
X v 
lO [QQQ] 110 
011 
E 
ADD A. (lX+d) A - 
A + (IX+d) 
X 
X 
V 
II 011 lOl 
DD 
19 
100 H 


10 lQQQ] llO 
101 
L 
- 
d - 
III A 
ADD A. (IY +d) A - A + (IY +d) 
X 
X 
V 
0 
II III 101 
FD 
19 
lO IQQQJ llO 
- 
d 


ADCA. s 
A - A+s+CY 
I' 
X 
X 
V 
[QQIJ 
s Is any of r. n. 


SUB s 
A - A-s 
I 
X 
X 
V 
[QIQ] 
(HL). (IX+d). 
(lY + d) liS shown 


SBC A. s 
A - A-s-CY 
X 
X 
V 
[QIT] 
for ADD instruction, 


ANDs 
A-Al\s 
X 
X 
P 
[QQ) 
The indicated bits 


OR s 
A-AVs 
X 
X ,P 
[jJ]J 
replace the [QQQ] in 
the ADD set above. 


XOR s 
A - A e s 
X 
X 
P 
[IQj] 


CPs 
A-s 
X 
X 
V 
[j}] 


INC r 
r - 
r + I 
X 
X 
V 
00 r (i]Q] 


INC (EL) 
(EL) -(HL)+I 
X 
X 
V 
00 110 IIW 
II, 
INC (IX+d) 
(IX+d) .,.. 
X 
X 
V 
II 011 101 
DD 
23 
(IX+d)+1 
00 llO IIQQ] 
- 
d - 
INC (lY +d) 
(lY+d) - 
X 
X 
V 
0 
II III 101 
'FD 
23 


(IY+d)+1 
00 llO IIQQ] 


d 
DEem 
m -m-I 
X 
X 
V 
[@] 
m is any of r. (HL). 
(IX+d). (lY+d) 
as shown for INC, 
DEC same format 
and states liS INC, 
Replace [QQ) with 
[@] in opcode, 
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General- 
Symbolic 
Flags 
Opcode 
No.of No.of M No.of T 
Purpose 
Mnemonic 
Operation 
S 
Z 
H 
P/V N C 
76 543 210 Hex Bytes 
Cycles States 
Commonts 
Arithmetic 
DAA 
Converts acc. content 
X 
X 
P 
00 100 III 27 
DeCimal adjust 
and 
into packed BCD 
accumulator. 
following add or 


CPU Control 
subtract with packed 
BCD operands. 
Groups 
CPL 
A-A 
X 
X 
00 101 III 2F 
Complement 
accumulator (one's 
complement) . 
NEG 
A-O-A 
X 
X 
V 
II 101 101 ED 
Negate acc. (two's 


01 000 100 44 
complement) . 


CCF 
CY - CY 
X 
X 
X 
00 III 111 3F 
Complement curry 


flag. 


SCF 
CY - 
I 
X 
X 
00 110 111 37 
4 
Set carry flag. 


NOP 
No operation 
X 
X 
00 000 000 00 
4 
HALT 
CPU halted 
X 
X 
01 110 110 76 
4 


01* 
IFF - 
a 
X 
X 
II 110 all F3 
4 
EI * 
IFF - 
I 
X 
X 
II 111 all FB 
4 


IMO 
Set interrupt 
X 
X 
II 101 101 ED 
8 
mode a 
01 000 110 46 


IMI 
Set interrupt 
X 
X 
II 101 101 ED 
mode 1 
01 010 110 56 
1M2 
Set interrupt 
X 
X 
II 101 101 ED 
mode 2 
01 all 110 5E 


NOTES: 
IFF indicates the interrupt enable f1ip·f1op. 
~ 
CY indicates the carry flip· flop. 
* indicates interrupts are not sampled at the end of EI or DI. 


C 
IS-Bit 
ADD HL, S8 
HL - 
HL+ss 
X 
X 
X 
00 ssl 001 
II 
~ 
6 


Arithmetic 
00 
BC 
~ 
ADC HL, S8 
HL - 
HL+ss+CY 
X 
X 
X 
V 
II 101 101 ED 
15 
01 
DE 
e:J 


Group 
01 ssl 010 
10 
HL 
II SP 
SBC HL, S5 
HL - 
HL-ss-CY 
X 
X 
X 
V 
II 101 101 ED 
15 


01 ssO 010 


ADD IX, pp 
IX - 
IX + pp 
X 
X 
X 
II all 101 DD 
15 
pp 
Reg. 


01 ppl 001 
00 BC 
01 
DE 
10 
IX 
II SP 


ADD IY, rr 
IY - 
IY + rr 
X 
X 
X 
II III 101 FD 
15 
rr 
Reg. 


00 rrl 001 
00 BC 
01 
DE 
10 
IY 


II SP 
INC ss 
ss - 
ss + 1 
X 
X 
00 ssO all 
6 


INC IX 
IX - 
IX + 1 
X 
X 
11 all 101 DD 
10 


00 100 all 23 


INCIY 
IY - 
IY + 1 
X 
X 
11 III 101 FD 
10 


00 100 all 23 


DECss 
ss - ss-1 
X 
X 
00 ssl all 
6 


DEC IX 
IX - 
IX-l 
X 
X 
11 all 101 DD 
10 


00 101 all 2B 


DECIY 
IY - IY-l 
X 
X 
11 III 101 FD 
10 
00 101 all 2B 


NOTES: 
ss is any of the register pairs BC, DE, HL, SP .. 
pp is any of the register pairs BC, DE, IX, SP. 
rr is any of the register pairs BC, DE, IY, SP. 


Rotate and 
Shift Group 
RLCA 
~-L[i~i}J 
X 
X 
00 000 III 
07 
Rotate left circular 
accumulator. 


RLA 
l@j~ 
X 
X 
00 010 III 
17 
Rotate left 
accumulator. 


RRCA 
L~~ 
X 
X 
00 001 111 
OF 
Rotate right Circular 
accumulator. 


RRA 
~@l 
X 
X 
00 all III 
IF 
Rotate right 
accumulator. 


RLC r 
X 
X 
II 001 all 
CB 
Rotate left circular 


OO[QQQ]r 
register r. 


RLC (HL) 
X 
X 
P 
II 001 all 
CB 
15 
~. 


00 [QQQ] 110 
000 
B 


001 
C 


RLC (lX+d) ~~::J 
X 
X 
P 
II all 101 
DD 
23 
010 
D 
a 
all 
E. 


r,(HL),(!X + d),(!Y + d) 
II 001 all 
CB 
100 
H 
- 
d - 
101 
L 


00 [QQQ] 110 
III 
A 


RLC (IY+d) 
X 
a 
X 
P 
II III 101 
FD 
23 


II 001 all 
CB 
- 
d - 
Instruction format 


l@j~ 
00 ~ 
110 
and states are as 
RLm 
X 
X 
P 
IQIQ] 
shown for RLC's. 


mar,(HLl.(lX+dJ.(IY +d) 
To form new 


L~~ 
I22Il 


opcode replace 


RRC m 
X 
X 
p 
lQQQ] or RLC's 
m .. r,(HLJ.(IX + dJ.(IY + d) 
with shown code. 


2001-001 
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Rotate and 
Symbolic 
Flags 
Opcode 
No.of No.of M No.of T 


Shift Group 
Mnemonic 
Operation 
S 
Z 
H 
P/V N 
C 
76 5'3 210 
Hex Bytes 
Cycles States 
Comments 
(Continued) 
RRm 
~@J l- 
X 
X 
P 
IQill 
m"r,(HL).(lX +dl.(IY +d) 


SLAm 
@]~o 
X 
X 
[iQQ] 
me r,(HL).'{IX + dl.(IY + d) 


SRAm 
dJ=D-~ 
X 
X 
I.@] 
m.,r,(HLl.(IX +d).(lY +d) 


SRL m 
o~@] 
X 
X 
P 
[ill] 


mE r,(HLl.(IX + dl.(IY + d) 


RLD 
EI$l 
!7jgO! I 
X 
X 
P 
II 101 101 
ED 
18 
Rotate digit left and 


A 
(HL) 
01 101 III 
6F 
right between 
the accumulator 


!7-4!3fol 
! /-3!!} ° I 


and location (HL). 
RRD 
I 
X 
a 
X 
P 
II 101 101 
ED 
18 
The content of the 


A 
(HL) 
01 100 III 
67 
upper half of 
the accumulator is 
unaffected. 


Bit Set. Reset 
BIT b, r 
Z - 
rb 
X 
X 
X 
X 
II 001 all CB 
~ 


and Test 
01 
b 
r 
000 B 
BIT b, (HL) 
Z - 
(HL)b 
X 
X 
'X 
X 
II 001 all CB 
12 
001 
C 
Group 
01 
b 
110 
010 
D 
BIT b, (IX + d)b Z - 
(IX + d)b 
X 
X 
X 
X 
II all 101 DD 
20 
all E 
11 001 011 CB 
100 H 
- 
d - 
101 
L 


01 
b 
110 
III A 
b 
Bit Tested 
BIT b, (lY +d)b Z - 
(IY +d)b 
X 
X 
X 
X 
11 111 101 FD 
20 
000 
a 
11 001 all CB 
001 
1 
d 
010 
2 


01 
b 
110 
all 
3 


100 
4 
101 
5 


110 
6 
III 
7 
SET b, r 
rb -,I 
X 
X 
11 001 all CB 
[ill b 
SET b, (HL) 
(HL)b - 
1 
X 
X 
II 001 all CB 
15 


[!) b 
110 


SET b, (IX+d) 
(lX'+d)b - 
1 
X 
X 
11 all 101 DD 
23 


II 001 all CB 
- 
d 


IDJ b 
110 
SET b, (IY +d) (IY+d)b - 
I 
X 
X 
11 III 101 FD 
23 
11 001 all CB 
d - 


[!] b 
110 


RES b, m 
mb - 
a 
X 
X 
[Q] 
To form new 
m. r, (HL), 
opcode replace 
(IX+d). 
[ill of SET b, s 


(IY+d) 
with [Q]. Flags 
and time states for 
SET instruction. 


NOTES: 
The notation mb Indicates bit b (0 to 7) or loc.tion m. 


Jump 
JP nn 
PC - 
nn 
X 
X 
11 000 all C3 
10 
Group 
n 
cc 
Condition 


JP cc, nn 
If condition cc is 
X 
X 
11 cc 010 
10 
000 NZ non· zero 
true PC - 
nn, 
001 
Z 
zero 
otherwise 
010 NC non· carry 
continue 
all C 
carry 


100 PO parity odd 
101 
PE parity even 


110 P 
sign positive 
JR e 
PC - PC+e 
X 
X 
00 all 000 18 
12 
111 
M sign neg.tive 
- 
e-2 - 
JR C, e 
If C = 0, 
X 
X 
00 III 000 38 
If condition not ~et. 


continue 
- 
e-2 - 
IfC = I, 
12 
If condition is met. 


PC - 
PC+e 


JR NC, e 
IfC = I, 
X 
X 
00 110 000 30 
If condition not met. 
continue 
- 
e-2 - 
If C = 0, 
12 
If condition is met. 


PC - 
PC+e 
JP Z, e 
If Z = a 
X 
X 
00 101 000 28 
If condition not met. 
continue 
- 
e-2 - 
If Z = I, 
12 
If condition is met. 


PC - 
PC+e 


JR NZ, e 
If Z = I, 
X 
X 
00 100 000 20 
If condition not met. 
continue 
- 
e-2 - 
If Z· = 0, 
12 
If condition is met. 


PC - PC+e 
JP (HL) 
PC - 
HL 
X 
X 
11 101 001 E9 


JP(IX) 
PC - 
IX 
X 
X 
11 011,101 DD 
11 101 001 E9 
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Jump Group 
Symbolic 
Flags 
Opcode 
No.of No.of M No.of T 
(Continued) 
Mnemonic 
Operation 
S 
Z 
H 
P/V N 
C 
76 543 210 Hex Bytes 
Cycles States 
Comments 


JP (lY) 
PC - 
IY 
X 
X 
II III 101 FD 
II 101 001 E9 


DJNZ, e 
B - 
B-1 
X 
X 
00 010 000 10 
If B = O. 


If B = 0, 
- 
e-2 - 
continue 
If B *- 0, 
13 
If B *- O. 
PC - 
PC+e 


NOTES: 
e represents the extension in the relative addressing mode. 
a is a signed two's complement number In the range < -126, 129 >. 
e - 2 in the opcode provides an effective address of pc + e as PC is incremented 
by 2 prior to the addition of e. 


Call and 
CALL nn 
(SP-I) - 
PCH 
X 
X 
II 001 101 CD 
17 
Return Group 
(SP-2) - 
PCL 
PC - 
nn 


CALL cc, nn 
If condition 
X 
X 
II cc 100 
10 
If cc is false. 
cc is false 
continue, 
17 
If cc is true. 
otherwise same as 
CALL nn 


RET 
PCL - 
(SP) 
X 
X 
11 001 001 C9 
10 
PCH - 
(SP+ 1) 
e 
RET cc 
If condition 
X 
X 
11 cc 000 
If cc is false. 
cc is false 
9 


continue, 
11 
If cc is true. 
otherwise 
cc 
Condition 
same as 
000 NZ non-zero 
RET 
001 Z 
zero 


RET! 
Return from 
X 
X 
11 101 101 ED 
14 
010 NC non-carry 
011 C 
carry 
interrupt 
01 001 101 4D 
100 PO parity odd 
RETN1 
Return from 
X 
X 
11 101 101 ED 
14 
101 PE parity even 
non·maskable 
01 000 101 45 
110 P 
sign positive 
interrupt 
111M sign negative 


RST p 
(SP-I) - 
PCH 
X 
X 
11 
t III 
·11 
~ 
(SP-2) - 
PCL 
000 OOH 
PCH - 
0 
001 
OSH 
PCL - 
p 
010 
IOH 
011 
ISH 
100 20H 
101 
2SH 


110 30H 
III 3SH 


NOTE: . 'RETN loads IFF2 - 
IFFI 


Input and 
IN A, (n) 
A - 
(n) 
X 
X 
11 011 011 DB 
11 
n toAD - 
A7 
Output Group 
- 
n - 
Ace. to AS - 
A15 
INr, (C) 
r - 
(C) 
. I 
X 
X 
P 
11 101 101 ED 
12 
C to AD - 
A7 
if r = 110 only the 
01 
r 000 
B to AS - A15 
flags will be affected 


CD 


INI 
(HL) - 
(C) 
X 
X 
X 
X 
X 
X 
11 101 101 ED 
16 
C to AO - 
A7 
B - B-1 
@ 


10 100 010 A2 
B to AS - A15 
HL - 
HL + 1 
INIR 
(HL) - 
(C) 
X 
X 
X 
X 
X 
X 
11 101 101 ED 
5 
21 
C to AD - 
A7 
B - B-1 
10 110010 B2 
(If B*-O) 
BtoAS- AI5 
HL - 
HL + 1 
4 
16 
Repeat until 
(If B=O) 


B = 0 
CD 


IND 
(HL) - 
(C) 
X 
X 
X 
X 
X 
X 
II 101 101 ED 
16 
C to AD - A7 
B - B-1 
@ 
10 101 010 AA 
BtoAS-·AI5 


HL - HL-I 
INDR 
(HL) - 
(C) 
X 
X 
X 
X 
X 
X 
11 101 101 ED 
5 
21 
C to AD - A7 
B - B-1 
10 III 010 BA 
(If B*-O) 
B to AS - AI5 
HL - HL-I 
4 
16 


Repeat until 
(II B=O) 


B = 0 
OUT (n). A 
(n) - 
A 
X 
X 
11 010 011 D3 
II 
n toAD - 
A7 
Ace. to AS - 
AI5 


OUT (C), r 
(C) - 
r 
X 
X 
11 101 101 ED 
12 
C toAO - A7 


CD 
01 
r 001 
BtoAS - AI5 


OUTI 
(C) - 
(HL) 
X 
X 
,X 
X 
X 
X 
II 101 101 ED 
16 
C to AD - A7 
B - B-1 
@ 


10 100011 A3 
B to AS - AI5 
HL - 
HL + I 
OT!R 
(C) - 
(HL) 
X 
1 
X 
X 
X 
X 
X 
11 101 101 ED 
5 
21 
C to AD - A7 
B - B-1 
10 110 011 B3 
(If B*-?) 
B to AS - 
A15 
HL - 
HL + I 
4 
16 
Repeat until 
(If B=O) 


B = 0 
CD 
OUTD 
(C) - 
(HL) 
X 
X 
X 
X 
X 
X 
11 101 101 ED 
16 
C to AD - A7 
B - B-1 
10 101 011 AB 
B to AS - AI5 
HL - HL-I 


NOTE: CD If the result of B-1 is zero the Z flag is set, otherwise it is reset. 


Q) Z flag is set upon instruction completion only. 
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Input and 
Symbolic 
Flags 
Opcode 
No.of No.of M No.of T 


Output Group Mnemonic 
Operation 
S 
Z 
H 
P/V N C 
76 543 210 Hex' Bytes 
Cycles States 
Comment. 


(Continued) 
Q) 
OTDR 
(C) - 
(HL) 
X 
I 
X 
X 
X 
X 
X 
II 101 101 ED 
5 
21 
C to AO - 
A7 
B - 
B-1 
10 III 011 
(If B*O) 
B to Aa - 
AI5 
HL - 
HL-I 
4 
16 
Repeat until B = 0 
. 
(If B=O) 


NOTE: (i) Z !lag IS set upon instruction completIon only. 


Summary of 
0., 
Do 
Flag 
Instruction 
S 
Z 
H 
P/V N 
C 
Comments 


Operation 
ADD A. s; ADC A, S 
X 
X 
V 
0 
I 
a·bit add or add with carry. 


SUB s; SBC A, s; CP s; NEG 
X 
X 
V 
I 
I 
a·bit subtract, subtract with carry, compare and negate accumulator. 
ANDs 
X 
X 
P 
0 
~} 
OR s, XOR s 
X 
X 
P 
0 
Logical operations. 


INCs 
X 
I 
X 
V 
0 
a·bit increment. 
DEC s 
X 
I 
X 
V 
I 
a·bit decrement. 
ADD DD, ss 
X 
X 
X 
0 
16·bit add. 
ADC HL, ss 
X 
X 
X 
V 
0 
16·bit add with carry. 


SBC HL, ss 
X 
X 
X 
V 
I 
16·bit subtract with carry. 
RLA,RLCA,RRA;RRCA 
X 
0 
X 
0 
Rotate accumulator. 
RL m; RLC m; RR m; 
X 
0 
X 
P 
0 
Rotate and shift locations. 
RRC m; SLA m; 
SRA m; SRL m 
RLD; RRD 
X 
X 
P 
Rotate digit left and right. 
DAA 
X 
I 
X 
P 
Decimal adjust accumulator. 


CPL 
X 
I 
X 
I 
Complement accumulator. 


SCF 
X 
0 
X 
0 
Set carry. 
CCF 
X 
X 
X 
0 
Complement carry. 
IN rIC) 
I 
I 
X 
0 
X 
P 
0 
Input register indirect. 
INI, IND, OUT!; OUTD 
X 
I 
X 
X 
X 
X 
I :} 
Block input and output. Z = 0 if B * 0 otherwise Z = O. 
INIR; INDR; OT!R; OTDR 
X 
I 
X 
X 
X 
X 
I 
LDI; LDD 
X 
X 
X· 0 
X 
0 :} 
Block tra'nsfer instructions. P/v = I if BC * 0, otherwise P/V = O. 
LDIR; LDDR 
X 
X 
X 
0 
X 
0 
CPI; CPIR; CPD; CPDR 
X 
X 
X 
X 
I 
Block search instructions. Z = I if A = (HL). otherwise Z = O. P/V = I 
if BC * 0, otherwise P/V = O. 


LD A, I, LD A, R 
I 
X 
X 
IFF 
The content of the interrupt enable flip·flop (IFF) is copied into the P/V flag. 
BIT b, s 
X 
X 
X 
X 
The state of bit b of location s is copied into the Z flag. 


Symbolic 
Symbol 
Operation 
Symbol 
Operation 
Notation 
S 
Sign flag. S = 1 if the MSB of the result is 1. 
I 
The flag is affected according to the result of the 


Z 
Zero flag. Z = 1 if the result of the operation is O. 
operation. 


P/V 
Parity or overflow flag. Parity (P) and overflow 
The flag is unchanged by the operation. 
(V) share the same flag. Logical operations affect 
0 
The flag is reset by the operation. 
this flag with the parity of the result while 
1 
The flag is set by the operation. 
arithmetic operations affect this flag with the 
X 
The flag is a "don't care." 


overflow of the result. If P/V holds parity, PlY 
V 
P/V flag affected according to the overflow result 
1 if the result of the operation is even, P/V = 0 if 
of the operation. 
result is odd. If PlY holds overflow, PlY = 1 if 
P 
PlY flag affected according to the parity result of 
the result of the operation produced an overflow. 
the operation. 
H 
Half-carry flag. H = 1 if the add or subtract 
Anyone of the CPU registers A. B, C, D, E, H, L. 
operation produced a carry into or borrow from 
Any 8-bit location for all the addressing modes 
bit 4 of the accumulator. 
allowed for the particular instruction. 
N 
AddlSubtract flag. N = 1 if the previous opera- 
ss 
Any 16-bit location for all the addressing modes 
tion was a subtract. 
allowed for that instruction. 
H&N 
Hand N flags are used in conjunction with the 
ii 
Anyone of the two index registers IX or IY. 


decimal adjust instruction (DAA) to properly cor- 
R 
Refresh counter. 
rect the result into packed BCD format following 
n 
8-bit value in range < 0, 255 >. 
addition or subtraction using operands with 
nn 
16-bit value in range < 0, 65535 >. 
packed BCD format. 
C 
CarrylLink flag. C = 1 if the operation produced 
a carry from the MSB of the operand or result. 


16 
2001-001 


Pin 
Ao-AlS' Address Bus (output, active High, 
Descriptions 
3-state). Ao-A15 form a 16-bit address bus. The 
Address Bus provides the address for memory 
data bus exchanges (up to 64K bytes) and for 
I/O device exchanges. 


BUSACIC Bus Acknowledge (output, active 
Low). Bus Acknowledge indicates to the 
requesting device that the CPU address bus, 
data bus. and control signals MREQ, IORQ, 
RD, and WR have entered their high- 
impedance states. The external circuitry 
can now control these lines. 
BUSREQ. Bus Request (input, active Low). 
Bus Request has a higher priority than NMI 
and is always recognized at the end of the cur- 
rent machine cycle. BUSREQ forces the CPU 
address bus, data bus, and control signals 
MREQ, IORQ, RD, and WR to go to a high- 
impedance state so that other devices can 
control these lines. BUSREQ is normally wire- 
ORed and requires an external pullup for 
these applications. Extended BUSREQ 
periods due to extensive DMA operations can 
prevent the CPU from properly refreshing 
dynamic RAMs. 


00-07' Data Bus (input/output, active High, 
3-state). Do-D7 constitute an 8-bit bidirectional 
data bus, used for data exchanges with 
memory and I/O. 


HALT. Halt State (output, active Low). HALT 
indicates that the CPU has executed a Halt 
instruction and is awaiting either a non- 
maskable or a maskable interrupt (with the 
mask enabled) before operation can resume. 
While halted, the CPU executes NOPs to 
maintain memory refresh. 


INT. Interrupt Request (input, active Low). 
Interrupt Request is generated by I/O devices. 
The CPU honors a request at the end of the 
current instruction if the internal software- 
controlled interrupt enable flip-flop (IFF) is 
enabled. INT is normally wire-ORed and 
requires an external pullup for these 
applications. 
IORQ. Input/Output Request (output, active 
Low, 3-state). IORQ indicates that the lower 
half of the address bus holds a valid I/O 
address for an I/O read or write operation. 
IORQ is also generated concurrently with MI 
during an interrupt acknowledge cycle to indi- 
cate that an interrupt response vector can be 
placed on the data bus. 


Ml. Machine Cycle One (output, active Low). 
MI, together with MREQ, indicates that the 
current machine cycle is the opcode fetch 
cycle of an instruction execution. MI, together 
with IORQ, indicates an interrupt acknowledge 
cycle. 


MREQ. Memory Request (output, active 
Low, 3-state). MREQ indicates that the address 
bus holds a valid address for a memory read or 
memory write operation. 


NMI. Non-Maskable Interrupt (input, negative 
edge-triggered). NMI has a higher priority 
than INT. NMI is always recognized at the end 
of the current instruction, independent of the 
status of the interrupt enable flip-flop, and 
automatically forces the CPU to restart at loca- 
tion 0066H. 


RD. Read (output, active Low, 3-state). RD 
indicates that the CPU wants to read data from 
memory or an I/O device. The addressed I/O 
device or memory should use this signal to 
gate data onto the CPU data bus. 


RESET. Reset (input, active Low). RESET 
initializes the CPU as follows: it resets the 
interrupt enable flip-flop, clears the PC and 
Registers I and R, and sets the interrupt status 
to Mode O. During reset time, the address and 
data bus go to a high-impedance state, and all 
control output signals go to the inactive state. 
Note that RESET must be active for a minimum 
of three full clock cycles before the reset 
operation is complete. 
RFSH. Refresh (output, active Low). RFSH, 
together with MREQ, indicates that the lower 
seven bits of the s'ystem's address bus can be 
used as a refresh address to the system's 
dynamiC memories. 


WAIT. Wait (input, active Low). WAIT 
indicates to the CPU that the addressed mem- 
ory or I/O devices are not ready for a data 
transfer. The CPU continues to enter a Wait 
state as long as this signal is active. Extended 
WAIT periods can prevent the CPU from 
refreshing dynamic memory properly. 
WR. Write (output, active Low, 3-state). WR 
indicates that the CPU data bus holds valid 
data to be stored at the addressed memory or 
I/O location. 
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CPU Timing 
The Z80 CPU executes instructions by pro- 
The basic clock period is referred to as a 
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ceeding through a specific sequence of opera- 
tions: 


• Memory read or write 


II I/O device read or write 


II Interrupt acknowledge 


Instruction Opcode Fetch. The CPU places 
the contents of the Program Counter (PC) on 
the address bus at the start of the cycle (Figure 
5). Approximately one-half clock cycle later, 
MREQ goes active. When active, RD indicates 
that the memory data can be enabled onto the 
CPU data bus. 


T, 
TW 


CLOCK 


Ao-A15 _-+-_..J 


« « 
~ 


T time or cycle, and three or more T cycles 
make up a machine cycle (MI, M2 or M3 for 
instance). Machine cycles can be extended 
either by the CPU automatically inserting one 
or more Wait states or by the insertion of one 
or more Wait states by the user. 


The CPU samples the WAIT input with the 
falling edge of clock state T2. During clock 
states T3 and T4 of an MI cycle dynamic RAM 
refresh can occur while the CPU starts 
decoding and executing the instruction. When 
the Refresh Control signal becomes active, 
refreshing of dynamic memory can take place. 


Ta 


----F/j/~-~r~ 
f-®11 
RFSH 
r- 
---------1 


NOTE: Tw-Wait cycle added when necessary for slow ancilliary devices. 


Figure 5. Instruction Opcode Fetch 


2005-882 


CPU 
Timing 
( Continued) 


2005-883 


Memory Read or Write Cycles. Figure 6 
shows the timing of memory read or write 
cycles other than an opcode fetch (Ml) cycle. 
The MREQ and RD signals function exactly as 
in the fetch cycle. In a memory write cycle, 


{ 


RD 


OPERA~~~~ 


00-0 7 


OPER~~II~~ 


MREQ also becomes active when the address 
bus is stable. The WR line is active when the 
data bus is stable, so that it can be used 
directly as an R/W pulse to most semi- 
conductor memories. 


{ 


WR 


Do-D7----------~--~--------~~--~~~------------~ 


Figure 6. Memory Read or Write Cycles 
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CPU 
Timing 
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Input or Output Cycles. Figure 7 shows the 
timing for an I/O read or I/O write operation. 
During I/O operations, the CPU automatically 


CLOCK 


inserts a single Wait state (Tw). This extra Wait 
state allows sufficient time for an I/O port to 
decode the address from the port address lines. 


AO-A7 __ +-J1~ __ ~ 
________ ~~~~ ----~-------H-4--~~,-- 


WAIT __ +-__ ~~~ 
__________ ~ 
__ ~~~-JI 


110 { 
READ 


OPERATION 


{ 


WR 


WRI~~ 


OPERATION 
---------~t:::::::::::::::~~::::::~~~::::::} 
00-0 7 


NOTE: Tw* = One Wait cycle automatically inserted by CPU. 


Figure 7. Input or Output Cycles 


Interrupt Request/Acknowledge Cycle. The 
CPU samples the interrupt signal with the ris- 
ing edge of the last clock cycle at the end of 
any instruction (Figure 8). When an interrupt 
is accepted, a special Ml cycle is generated. 


During this Ml cycle, IORQ becomes active 
(instead of MREQ) to indicate that the inter- 
rupting device can place an a-bit vector on the 
data bus. The CPU automatically adds two 
Wait states to this cycle. 


AO-A15 
PC 
-----------+--,~--------------~------~~~----~_4~J~---- 


I.-------~@D~------~I 


WAIT 
----------_4--------------~--------*_--~-J 


00-07 


NOTE: 1)TL = Last state of previous instruction. 
2) Two Wait cycles automatically inserted by CPU(*). 


Figure 8. Interrupt Request/Acknowledge Cycle 
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CPU 
Timing 
(Continued) 
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Non-Maskable Interrupt Request Cycle. 
NMI is sampled at the same time as the mask- 
able interrupt input INT but has higher priority 
and cannot be disabled under software control. 
The subsequent timing is similar to that of a 


CLOCK 


normal instruction fetch except that data put 
on the bus by the memory is ignored. The 
CPU instead executes a restart (RST) operation 
and jumps to the NMI service routine located 
at address 0066H (Figure 9). 


Ao-A15 -----------+J-}__l---~--__l--J.l__----+--I_---_+' 


• Although NMI is an -asynchronous input, to ~antee its being 
recognized on the following machine cycle, NMI's falling edge 
must occur no later than the rising edge of the clock cycle 
preceding TLAST. 


Figure 9. Non-Maskable Interrupt Request Operation 


B~s Request/Acknowledge Cycle. The CPU 
samples BUSREQ with the rising edge of the 
last clock period of any machine cycle (Figure 
10). If BUSREQ is active, the CPU sets its 
address, data, and MREQ, IORQ, RD, and WR 


lines to a high-impedance state with the rising 
edge of the next clock pulse. At that time, any 
external device can tale control of these lines, 
usually to transfer data between memory and 
I/O devices. 


Tx 
Tx 


CLOCK 


BUSREQ 
--------~~~--~4---~,~------J 


Tx 
T, 


Ao-A'5 __________ 
~-..r~,J----...;.,;;;.;.;,;...----'"'"'i""1 


DO-D7 ==========j=}-......"J----~!!!...----_i~ 


MREQ ------------!-,L 
~~~--~--------J-;-......"J----~;.;.;,;...-----l-1 


-®- 


HALT 
UNCHANGED 
----------------+--------------------------- 


NOTE: TL = Last state of any M cycle. 
TX = An arbitrary clock cycle used by requesting device. 


Figure 10. Z-BUS Request/Acknowledge Cycle 
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Halt Acknowledge Cycle. When the CPU 
receives a Halt instruction, it executes NOP 
states until either an INT or NMI input is 


received. When in the Halt state, the HALT 
output is active and remains so until an inter- 
rupt is received (Figure 11). 


M1 
• I • 
M1 
• I • 
M1 


CLOCK 
~. 
~ 
~ 
~ 
~ 
~ 
~ 


36 
. 
-® 
HALT=::~ 


Received 
~_. 
___________ 
_ 


NMI 
U- 


NOTE: lNT will also force a Halt exit. 
·See note, Figure 9. 


Figure 11. Halt Acknowledge Cycle 


Reset Cycle. RESET must be active for at least 
three clock cycles for the CPU to properly 
accept it. As long as RESET remains active, the 
address and data buses float, and the control 
outputs are inactive. Once RESET. goes 


inactive, three internal T cycles are consumed 
before the CPU resumes normal processing 
operation. RESET clears the PC register, so the 
first opcode fetch will be to location 0000 
(Figure 12). 


1 __ ---M1--- - 
- 
-: 


CLOCK 


00-0 7 
-@~~----~~------~------------- 
~,,-- 
FLOAT 


-@- 


M1 
I 
----------------~ 


) 


1!R~ 
R~~--------~~r7~7~~----~/~/~---------------T------------ 


RFSH, 
1111/11 
\'---__ 
_ 
BUSACK 
- 
HALT 


Figure ~2. Reset Cycle 
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AC Characteristics 


Z80 CPU 
Z80A CPU 
Z80B CPU 
Z80H cPut 


Number Symbol 
Parameter 
Min 
Max 
Min 
Max 
Min 
Max 
Min 
Max 


TcC 
Clock Cycle Time 
400* 
250* 
165* 
125* 


2 
TwCh 
Clock Pulse Width (High) 
180* 
110* 
65* 
55* 


3 
TwCl 
Clock Pulse Width (Low) 
180 
2000 
110 
2000 
65 
2000 
55 
2000 


4 
TfC 
Clock Fall Time 
30 
30 
20 
10 


5-TrC 
Clock Rise Time 
30 
30 
20- 
-10- 


6 
TdCr(A) 
Clock I to Address Valid Delay 
145 
110 
90 
80 


7 
TdA(MREQf) 
Address Valid to MREQ 
125* 
65* 
35* 
20* 
I Delay 


8 
TdCf(MREQf) 
Clock I to MREQ I Delay 
100 
85 
70 
60 


9 
TdCr(MREQr) 
Clock I to MREQ t Delay 
100 
85 
70 
60 
10 - 
TwMREQh -- MREQ Pulse Width (High) --- 170* 
110* 
65* 
45*- 


11 
TwMREQl 
MREQ Pulse Width (Low) 
360* 
220* 
135* 
100* 
I 
12 
TdCf(MREQr) 
Clock I to MREQ t Delay 
100 
85 
70 
60 


13 
TdCf(RDf) 
Clock I to RD I Delay 
130 
95 
80 
70 
9 
14 
TdCr(RDr) 
Clock I to RD I Delay 
100 
85 
70 
60 


15 - 
TsD(Cr) --- Data Setup Time to Clock I --- 50 
35 
30 
30- 


16 
ThD(RDr) 
Data Hold Time to RD t 
0 
0 
0 
0 


17 
TsWAIT(Cf) 
WAIT Setup Time to Clock I 
70 
70 
60 
50 


18 
ThWAIT(Cf) 
WAIT Hold Time after Clock I 
0 
0 
0 
0 


19 
TdCr(Mlf) 
Clock I to Ml I Delay 
130 
100 
80 
70 


20 - 
TdCr(Mlr) -- Clock I to Ml t Delay 
130 
100 
80- 
-70- 


21 
TdCr(RFSHf) 
Clock I to RFSH I Delay 
180 
130 
110 
95 


22 
TdCr(RFSHr) 
Clock I to RFSH t Delay 
150 
120 
100 
85 
23 
TdCf(RDr) 
Clock I to RD I Delay 
110 
85 
70 
60 


24 
TdCr(RDf) 
Clock t to RD I Delay 
100 
85 
70 
60 


25 - 
TsD(Cf) --- Data Setup to Clock I during -- 60 
50 
40 
30- 


M2, M3, M4 or Ms Cycles 


26 
TdA(IORQf) 
Address Stable prior to IORQ I 
320* 
180* 
110* 
75* 


27 
TdCr(IORQf) 
Clock t to IORQ I Delay 
90 
75 
65 
55 


28 
TdCf(IORQr) 
Clock I to IORQ t Delay 
110 
85 
70 
60 


29 
TdD(WRf) 
Data Stable prior to WR I 
190* 
80* 
25* 
5* 


30 - 
TdCf(WRf) -- Clock I to WR I Delay 
90 
80 
70- - 
-60- 


31 
TwWR 
WR Pulse Width 
360* 
220* 
135* 
100* 


32 
TdCf(WRr) 
Clock I to WR t Delay 
100 
80 
70 
60 


33 
TdD(WRf) 
Data Stable prior to WR I 
20* 
-10* 
-55* 
55* 


34 
TdCr(WRf) 
Clock t to WR I Delay 
80 
65 
60 
55 


35 - 
TdWRr(D) -- Data Stable from WR t 
120* 
60* 
30* 
15*- 


36 
TdCf(HALT) 
Clock I to HALT t or I 
300 
300 
260 
225 


37 
TwNMI 
NMI Pulse Width 
80 
80 
70 
60* 


38 
TsBUSREQ(Cr) BUSREQ Setup Time to Clock t 
80 
50 
50 
40 


'For clock periods other than the minimums shown in the table, 
calculate parameters using the expressions in the table on the 
following page. 
r Units in nanoseconds (ns). All timings are preliminary and 
subject to change. 
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AC Characteristics (Continued) 


Z80 CPU 
Z80A CPU 
Z80B CPU 
Z80H cPut 


Number Symbol 
Parameter 
Min 
Max 
Min 
Max 
Min 
Max 
Min 
Max 


39 
ThBUSREQ(Cr) 
BUSREQ Hold Time after Clock I 
0 
0 
0 
0 
40 -TdCr(BUSACKf)-Clock I to BUSACK I Delay 
120 
100 
90--- -80 


41 
TdCf(BUSACKr) Clock I to BUSACK I Delay 


42 
TdCr(Dz) 
Clock I to Data Float Delay 


43 
TdCr(CTz) 
Clock I to Control Outp~Float 
DelaliMREQ, IORQ, RD, 
and WR} 


44 
TdCr(Az) 
Clock I to Address Float Delay 
45-TdCTr(A) --MREQ I, IORQ I, RD I, and--160* 


, 
WR I to Address Hold Time 


46 
TsRESET(Cr) 
RESET to Clock I Setup Time 
47 
ThRESET(Cr) 
RESET to Clock I Hold Time 


48 
TsINTf(Cr) 
INT to Clock I Setup Time 


49 
ThINTr(Cr} 
INT to Clock I Hold Time 


50 -TdMlf(IORQf)-Ml I to IORQ I Delay 


51 
TdCf(IORQf) 
Clock I to IORQ I Delay 


52 
TdCf(IORQr) 
Clock I to IORQ I Delay 


53 
TdCf(D) 
Clock I to Data Valid Delay 


"For clock periods ~ther than the minimums shown in the table, 
calculate parameters using the following expressions. Calculated 
values above assumed TrC = TfC = 20 ns. 
i Units in nanoseconds (ns). All timings are preliminary and 
subject to change. 


Footnotes to AC Characteristics 


90 


80 


920* 


110 
100 
90 


90 
90 
80 


110 
80 
70 


110 
90 
80 
80* 
35* 


60 
60 
0 
0 
0 
80 
70 


0 
0 
0 


565* 
365* 


110 
85 
70 
100 
85 
70 
230 
150 
130 


Number Symbol 
zao 
Z80A 
Z80B 


20*- 


45 


55 


270*- 


TeC 


TwCh 


TwCh + TwC1 + TrC + TfC 
TwCh + TwC1 + TrC + TfC 
TwCh + TwC1 + TrC + TfC 
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2 
Although static by design, 
TwCh of greater than 200 p.s 
is not guaranteed 


Although static by design, 
TwCh of greater than 200 p.s 
is not guaranteed 


Although static by deSign, 
TwCh of greater than 200 p.s 
is not guaranteed 


7 -TdA(MREQf)-TwCh + TfC - 75 ----TwCh + TfC - 65----TwCh + TfC - 50---- 


10 
TwMREQh 
TwCh + TfC - 30 
TwCh + TfC - 20 
TwCh + TfC - 20 


11 
TwMREQl 
TcC - 40 
TcC - 30 
TcC - 30 


26 
TdA(lORQf) 
TcC - 80 
TcC - 70 
TcC - 55 


29 
TdD(WRf) 
TcC - 210 
TeC - 
170 
TcC - 
140 


31-TwWR---TcC - 40-------TcC - 30 
TcC - 30------- 


33 
TdD(WRf) 
TwC1 + TrC - 180 
TwC1 + TrC - 
140 
TwC1 + TrC - 
140 


TdWRr(D) 
TwC1 + Tre - 80 
35 


45 


50 


TdCTr(A) 
TwC1 + TrC - 40 


TdMlf(IORQf) 2TcC + TwCh + TfC - 80 


AC Test Conditions: 
VIH = 2.0 V 
VIL = 0.8 V 
VIHC = VCC -0.6 V 
VILC = 0.45 V 


VOH = 2.0 V 
VOL = 0.8 V 
FLOAT = ±0.5 V 


TwC1 + TrC - 70 
TwC1 + TrC - 55 


TwC1 + TrC - 50 
TwC1 + TrC - 50 


2TcC + TwCh + TfC - 65 
2TcC + TwCh + TfC - 50 


80 
70 


60 


70 


0 


0 


60 
60 
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Absolute 
Maximum 
Ratings 


Standard 
Test 
Conditions 


DC 
Character- 
istics 


Capacitance 


8085-029 


Storage Temperature ........ -65°C to + 150 °C 
Temperature 
under Bias ........ Specified operating range 
Voltages on all inputs and 
outputs with respect to ground. -0.3 V to + 7 V 
-Power Dissipation ..... ~ .............. 1.5 W 


The characteristics below apply for the 
follOWing standard test conditions, unless 
otherwise noted. All voltages are referenced to 
GND (0 V). Positive current flows into the 
referenced pin. Available operating 
temperature ranges are: 


[J S* = O°C to + 70°C, 


+4.75 V :S Vee:S +5.25 V 


IJ E* = -40°C to +85°C, 


+ 4.75 V :S Vee:S + 5.25 V 


[J M* = -55°C to + 125°C, 


+ 4.5 V :S Vee:s + 5.5 V 


'See Ordering Information section for package 
temperature range and product number. 


Symbol 
Parameter 


VILe 
Clock Input Low Voltage 


VIHe 
Clock Input High Voltage 


VIL 
Input Low Voltage 


VIH 
Input High Voltage 


VOL 
Output Low Voltage 


VOH 
Output High Voltage 


Icc 
Power Supply Current 


Z80 
Z80A 
Z80B 


III 
Input Leakage Current 


ILO 
3-State Output Leakage Current in Float 


L For military grade parts. ICC is 200 rnA. 
2. Typical rate for lBOA is 90 rnA. 


Symbol 
Parameter 


CeLOeK 
Clock Capacitance 


C IN 
Input Capacitance 


COUT 
Output Capacitance 


TA = 25°C. f = 1 MHz, 


Stresses greater than those listed under Absolute Maxi- 


mum Ratings may cause permanent damage to' the device. 
This is a stress rating only; operation'of the device at any 
condition above those indicated in the operational sections 
of these specifications is not implied. Exposure to absolute 
maximum rating conditions for extended periods may affect 
device reliability. 


All ac parameters assume a load capacitance 
of 100 pF. Add 10 ns delay for each 50 pF in- 
crease in load up to a maximum of 200 pF for 
the data bus and 100 pF for address and control 
lines. 


+5V 


Min 
Max 
Unit 
Test Condition 


-0.3 
0.45 
V 


Vee-·6 
Vee + .3 
V 


-0.3 
0.8 
V 


2.0 
Vee 
V 


0.4 
V 
IoL= 1.8 rnA 


2.4 
V 
IOH = -250 p.A 


1501 
rnA 


2002 
rnA 


200 
rnA 
10 
p.A 
VIN = 0 to .vee 


-10 
103 
p.A 
VOUT = 0.4 to Vee 


3. A15-AO. D7-DO. MREQ. IORQ. RD. and WR. 


Min 
Max 
Unit 
Note 


35 
pF 


5 
pF 
Unmeasured pins 
returned to ground 
10 
pF 
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Ordering 
Product 
Package/ 
Product 
Package/ 
Information 
Number 
Temp 
Speed 
Description 
Number 
Temp 
Speed 
Description 


28400 
CE 
2.5 MHz 
280 CPU (40-pin) 
28400A 
CMB 
4.0 MHz 
280A CPU (40-pin) 


28400 
CM 
2.5 MHz 
Same as above 
28400A 
CS 
4.0 MHz 
Same as above 


28400 
CMB 
2.5 MHz 
Same as above 
28400A 
DE 
4.0 MHz 
Same as above 


28400 
CS 
2.5 MHz 
Same as above 
28400A 
DS 
4.0 MHz 
Same as above 


28400 
DE 
2.5 MHz 
Same as above 
28400A' 
PE 
4.0 MHz 
Same as above 


28400 
DS 
2.5 MHz 
Same as above 
28400A 
PS 
4.0 MHz 
Same as above 


28400 
PE 
2.5 MHz 
Same as above 
28400B 
CS 
6.0 MHz 
280B CPU (40-pin) 


28400 
PS 
2.5 MHz 
Same qS above 
28400B 
DS 
6.0 MHz 
Same as above' 


28400A 
CE 
4.0 MHz 
280A CPU (40-pin) 
28400B 
PS 
6.0 MHz 
Same as above 


28400A 
CM 
4.0 MHz 
Same as above 


"NOTES: C == Ceramic, D == Cerdip, P == Plastic; E == -40°C to + 85°-C, M == -55°C to + 125°C, MB == -55°C to + 125°C with 
MIL-STD-883 Class B processing, S == O°C to +70°C. 
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Zilog 


Features 


General 
Description 


2032-0125, 0126 


.. Transfers, searches and search/transfers in 
Byte-at-a-Time, Burst or Continuous modes. 
Cycle length and edge timing can be pro- 
grammed to match the speed of any port. 


II Dual port addresses (source and destination) 
generated for memory-to-I/O, memory- 
to-memory, or I/O-to-I/O operations. 
Addresses may be fixed or automatically 
incremented! decremented. 


r.:J Next-operation loading without disturbing 
current operations via buffered starting- 


The 2-80 DMA (Direct Memory Access) is a 
powerful and versatile device for controlling 
and processing transfers of data. Its basic 
function of managing CPU-independent 
transfers between two ports is augmented by 
an array of features that optimize transfer 
speed and control with little or no external 
logic in systems using an 8- or 16-bit data bus 
and a 16-bit address bus. 
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address registers. An entire previous 
sequence can be repeated automatically. 


• Extensive programmability' of functions. 


CPU can read c~mplete channel status. 


II Standard 2-80 Family bus-request and 
prioritized interrupt-request daisy chains 
implemented without external logic. 
Sophisticated, internally modifiable inter:- 
rupt vectoring. 


Il3 Direct interfacing to system buses without 
external logic. 


Transfers can be done between any two ports 
(source and destination), including memory-to- 
I/O, memory-to-memory, and I/O-to-I/O. Dual 
port addresses are automatically generated for 
each transaction and may be either fixed or 
incrementing/decrementing. 'In addition, bit- 
maskable byte searches can be performed 
either concurrently with transfers or as an 
operation in itself. 
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General 
'" 
The Z-80 DMA contains direct interfacing to 
Description 
and independent control of system buses, as 
(Continued) 
well as sophisticated bus and interrupt con- 
trols. Many programmable features, including 
variable cycle timing and auto-restart, 
minimize CPU software overhead. They are 
especially useful in adapting this special- 


Functional 
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Classes of Operation. The Z-80 DMA has 
three basic classes of operation: 


II Transfers of data between two ports (memory 
or I/O peripheral) 


13 Searches for a particular 8-bit maskable 
byte at a single port in memory or an I/O 
peripheral 


m Combined transfers with simultaneous 
search between two ports 


\ Figure 4 illustrates the basic functions 


s~rved by these classes of operation. 
\ During a transfer, the DMA assumes control 
of\the system address and data buses. Data is 
read from one addressable port and written to 
the\other addressable port, byte by byte. The 
ports may be programmed to be either system 
mai1\ memory or peripheral I/O devices. Thus, 
a bldck of data may be written from one 


peri~heral to another, from one area of main 
mem6ry to another, or from a peripheral to 
main ~emory and vice versa. 
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Figure 3. Typical Z-BO Environment 


purpose transfer processor to a broad variety 
of memory, I/O and CPU environments. 
The Z-80 DMA is an n-channel silicon-gate 


depletiqn-Ioad device packaged in a 40-pin 
plastic or ceramic DIP. It uses a single + 5 V 
power supply and the standard Z-80 Family 
single-phase clock. 


During a search-only operation, data is read 
from the source port and compared byte by 
byte with a DMA-internal register containing a 
programmable match byte. This match byte 
may optionally be masked so that only cert'ain 
bits within the match byte are compared. 
Search rates up to 1.25M bytes per second can 
be obtained with the 2.5 MHz Z-80 DMA or 2M 
bytes per second with the 4 MHz Z-80A DMA. 
In combined searches and transfers, data 
is transferred between two ports while 
simultaneously searching for a bit-maskable 
byte match. 
Data transfers or searches can be pro- 


grammed to stop or interrupt under various 
conditions. In addition, CPU-readable status 
bits can be programmed to reflect the 
condition. 
Modes of Operation. The Z-80 DMA can be 
programmed to operate in one of three transfer 
and! or search modes: 


IJ Byte-at-a-Time: data operations are per- 


formed one byte at a time. Between each 
byte operation the system buses are released 
to the CPU. The buses are requested again 
for each succeeding byte operation. 


ra Burst: data operations continue until a 
port's Ready line to the DMA goes inactive. 
The DMA then stops and releases the system 
buses after completing its current byte 
operation. 


[J Continuous: data operations continue until 
the end of the programmed block of data is 
reached before the system buses are 
released. If a port's Ready line goes inactive 
before this occurs, the DMA simply pauses 


. until the Ready line comes active again. 


Z·80 DMA 


1. Search memory 
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2. Transfer memory·la-memory (optional search) 
3. Transfer memory·la-IIO (optional search) 
4. Search 110 
5. Transfer 110·10·110 (optional search) 


Figure 4. Basic Functions of the Z-BO DMA 
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In all modes, once a byte of data is read into 
the DMA, the operation on the byte will be 
completed in an orderly fashion, regardless of 
the state of other signals (including a port's 
Ready line). 
Due to the DMA's high-speed buffered 
method of reading data, operations on one 
byte are not completed until the next byte is 
read in. This means that total transfer or 
search block lengths must be two or more 
bytes, and that block lengths programmed into 
the DMA must be one byte less than the 
desired block length (count is N-I where N is 
the block length). 
Commands and Status. The 2-80 DMA has 
several writable control registers and readable 
status registers available to the CPU. Control 
bytes can be written to the DMA whenever the 
DMA is not controlling the system buses, but 
the act of writing a control byte to the DMA 
disables the DMA until it is again enabled by a 
speCific command. Status bytes can also be 
read at any such time, but writing the Read 
Status Byte command or the Initiate Read 
Sequence command disables the DMA. 
Control bytes to the DMA include those 
which effect immediate command actions such 
as enable, disable, reset, load starting-address 
buffers, continue, clear counters, clear status . 
bits and the like. In addition, many mode- 
setting control bytes can be written, including 
mode and class of operation, port configura- 
tion, starting addresses, block length, address 
counting rule, match and match-mask byte, 
interrupt conditions, interrupt vector, status- 
affects-vector condition, pulse counting, auto 
restart, Ready-line and Wait-line rules, and 
read mask. 
Readable status registers include a general 
status byte reflecting Ready-line, end-of-block, 
byte-match .and interrupt conditions, as well as 
2-byte registers for the current byte count, 
Port A address and Port B address. 


Variable Cycle. The 2-80 DMA has the 
unique feature of programmable operation- 
cycle length. This is valuable in tailoring the 
DMA to the particular requirements of other 
system components (fast or slow) and max- 
imizes the data-transfer rate. It also eliminates 
external logic for signal conditioning. 
There are two aspects to the variable cycle 
feature. First, the entire read and write cycles 
(periods) associated with the source and 
destination ports can be independently pro- 
grammed as 2, 3 or 4 T-cycles long (more if 
Wait cycles are used), thereby increasing or 


decreasing the speed with which all DMA 
signals change (Figure 5). 
Second, the four signals in each port 
specifically associated with transfers of data 
(1/0 Request, Memory Request, Read, and 
Write) can each have its active trailing edge 
terminated one-half T -cycle early. This adds a 
further dimension of flexibility and speed, 
allowing such things as shorter-than-normal 
Read or Write signals that go inactive before 
da ta starts to change. 
Address Generation. Two 16-bit addresses are 
generated by the Z-80 DMA for every transfer 
operation, one address for the source port and 
another for the destination port. Each address 
can be either variable or fixed. Variable 
addresses can increment or decrement from 
the programmed starting address. The fixed- 
address capability eliminates the need for 
separate enabling wires to 1/0 ports. 


Port addresses are multiplexed onto the 
system address bus, depending on whether the 
DMA is reading the source port or writing to 
the destination port. Two readable address 
counters (2 bytes each) keep the current 
address of each port. 
Auto Restart. The starting addresses of either 
port can be reloaded automatically at the end 
of a block. This option is selected by the Auto 
Restart control bit. The byte counter is cleared 
when the addresses are reloaded. 
The Auto Restart feature relieves the CPU of 
software overhead for repetitive operations 
such as CRT refresh and many others. More- 
over, when the CPU has access to the buses 
during byte-at-a-time or burst transfers, dif- 
ferent starting addressas can be written into 
buffer registers during transfers, causing the 
Auto Restart to begin at a new location. 
Interrupts. The 2-80 DMA can be programmed 
to interrupt the CPU on three conditions: 


• Interrupt on Ready (before requesting bus) 


• Interrupt on Match 


• Interrupt on End of Block 
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Figure 5. Variable Cycle Length 
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Any of these interrupts cause an interrupt- 
pending status bit to be set, and each of them 
can optionally alter the DMA's interrupt vec- 
tor. Due to the buffered constraint mentioned 
under "Modes of Operation," interrupts on 
Match at End of Block are cau'sed by matches 
to the byte just prior to the last byte in the 
block. 
The DMA shares the Z-80 Family's elaborate 
interrupt scheme, which provides fast inter- 
rupt service in real-time applications. In a 
Z-80 CPU environment, the DMA passes its 
internally modifiable 8-bit interrupt vector to 
the CPU, which adds an additional eight bits 
to form the memory address of the interrupt- 
routine table. This table contains the address 
of the beginning of the interrupt routine itself. 


Ao-AIS. System Address Bus (output, 3-state). 
Addresses generated by the DMA are sent to 
both source and destination ports (main 
memory or I/O peripherals) on these lines. 


BAl. Bus Acknowledge In (input, active Low). 
Signals that the system buses have been 
released for DMA control. In multiple-DMA 
configurations, the BAI pin of the highest 
priority DMA is normally connected to the Bus 
Acknowledge pin of the CPU. Lower-priority 
DMAs have their BAI connected to the BAO of 
a higher-priority DMA. 


BAO. Bus Acknowledge Out (output, active 
Low). In a multiple-DMA configuration, this 
pin signals that no other higher-priority DMA 
has requested the system buses.BAI and BAO 
form a daisy chain for multiple-DMA priority 
resolution over bus control. 


BUSREQ. Bus Request (bidirectional, active 
Low, open drain). As an output, it sends 
requests for control of the system address bus, 
data bus and control bus to the CPU. As an 
input, when multiple DMAs are strung 
together in a priority daisy chain via BAI and 
BAO, it senses when another DMA has 
requested the buses and causes this DMA to 
refrain from bus requesting until the other 
DMA is finished. Because it is a bidirectional 
pin, there cannot be any buffers between this 
DMA and any other DMA. It can, however, 
have a buffer between it and the CPU because 
it is unidirectional into the CPU. A pull-up 
res'istor is connected to this pin. 
CE/WAIT. Chip Enable and Wait (input, 
active Low). Normally this functions only as a 
CE line, but it can also be programmed to 
serve a WAIT function. As a CE line from the 
CPU, it becomes active when WR and IORQ 
are active and the I/O port address on the 


In this process, CPU control is transferred 
directly to the interrupt routine, so that the 
next instruction executed after an interrupt 
acknowledge is the first instruction of the inter- 
rupt routine itself. 
Pulse Generation. External devices can keep 
track of how many bytes have been transferred 
by using the DMA's pulse output, which pro- 
vides a signal at 256-byte intervals. The inter- 
val sequence may be offset at the beginning by 
1 to 255 bytes. 
The Interrupt line outputs the pulse signal in 
a manner that prevents misinterpretation by 
the CPU as an interrupt request, since it only 
appears when the Bus Request and Bus 
Acknowledge lines are both active. 


system address bus is the DMA's address, 
thereby allOWing a transfer of control or com- 
mand bytes from the CPU to the DMA. As a 
WAIT line from memory or I/O devices, after 
the DMA has received a bus-request ack- 
nowledge from the CPU, it causes wait states 
to be inserted in the· DMA' s operation cycles 
thereby slowing the DMA to a speed that 
matches the memory or I/O device. 


CLK. System Clock (input). Standard Z-80 
single-phase clock at 2.5 MHz (Z-80 DMA) or 
4.0 MHz (Z-80A DMA). For slower system 
clocks, a TTL gate with a pullup resistor may 
be adequate to meet the timing and voltage 
level specification. For higher-speed systems, 
use a clock driver with an active pullup to 
meet the VIH specification and risetime 
requirements. In all cases there should be a 
resistive pullup to the power supply of 10K 
ohms (max) to ensure proper power when the 
DMA is reset. 
' 
Do-D7. System Data Bus (bidirectional, 
3-state). Commands from the CPU, DMA 
status, and data from memory or I/O 
peripherals are transferred on these lines. 


lEI. Interrupt Enable In (input, active High). 
This is used with IEO to form a priority daisy 
chain when there is more than one interrupt- 
driven device.'A High on this line indicates 
that no other device of higher priority is being 
serviced by a CPU interrupt service routine. 


lEO. Interrupt Enable Out (output, active 
High). lEO is High only if IEI is High and the 
CPU is not servicing an interrupt from this 
DMA. Thus, this signal blocks'lower-priority 
devices from interrupting while a higher- 
priority device is being serviced by its CPU 
interrupt service routine. 


Pin 
Description 
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INT/PULSE. Interrupt Request (output, active 
Low, open drain). This requests a CPU inter- 
rupt. The CPU acknowledges the interrupt by 
pulling its IORQ output Low during an Ml 
cycle. It is typically connected to the INT pin 
of the CPU with a pullup resistor and tied' to 


, all other INT pins in the system. This pin can 
also be used to generate periodiC pulses to an 
external device. It can be used this way only 
when the DMA is bus master (Le., the CPU's 
BUSREQ and BUSACK lines are both Low 
and the CPU cannot see interrupts). 
IORQ. Input/Output Request (bidirectional, 
active Low, 3-state). As an input, this indicates 
that the lower half of the address bus holds a 
valid I/O port address for transfer of control or 
status bytes from or to the CPU, respectively; 
thisDMA is the addressed port if its CE pin 
and its WR or RD pins are simultaneously 
active. As an output, after the DMA has taken 
control of the system bUf)es, it indicates that 
the 8-bit or 16-bit address bus holds a valid 
port address for another I/O device involved in 
a DMA transfer of data. When IORQ and MI 
are both active simultaneously, an interrupt 
acknowledge is indicated. 
Ml. Machine Cycle One (input, active Low). 
Indicates that the current CPU machine cycle 
is an instruction fetch. It is used by the DMA 
to decode the return-from-interrupt instruction 
(RET!) (ED-4D) sent by the CPU. During two- 
byte instruction fetches, MI is active as each 


The internal structure of the 2-80 DMA 
includes driver and receiver circuitry for inter- 
facing with an 8-bit system data bus, a 16-bit 
system address bus, and system control lines 
(Figure 6). In a 2-80 CPU environment, the 
DMA can be tied directly to the analogous pins 
on the CPU (Figure 7) with no additional buf- 
fering, except for the CE/WAIT line. 
The DMA's internal data bus interfaces with 
the system data bus and services' all internal 
logic and registers. Addresses generated from 
this logic for Ports A and B (source and des- 
tination) of the DMA's single transfer channel 
are multiplexed onto the system address bus. 


SYSTEM 
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opcode byte is fetched. An interrupt ack- 
nowledge is indicated when both Wand 
IORQ are active. 
MREQ. Memory Request (output, active Low, 
3-state). This indicates that the address bus 
holds a valid address for a memory read or 
write operation. After the DMA has taken con- 
trol of the system buses, it indicates a DMA 
transfer request from or to memory. 


RD. Read (bidirectional, active Low, 3-state). 
As an input, this indicates that the CPU wants 
to read status bytes from the DMNs read 
registers. As an output, after the DMA has 
taken control of the system buses, it indicates a 
DMA-controlled read from a memory or.I/O 
port address. 
RDY. Ready (input, programmable active Low 
or High). This is monitored by the DMA to 
determine when a peripheral device associated 
with a DMA port is ready for a read or write 
operation. Depending on the mode of DMA 
operation (Byte, Burst or Continuous), the RDY 
line indirectly controls DMA activity by caus- 
ing the BUSREQ line to go Low or High. 


WR. Write (bidirectional, active Low, 3-state). 
As an input, this indicates that the CPU wants 
to write control or command bytes to the DMA 
write registers. As an output, after the DMA 
has taken control of the system buses, it 
indicates a DMA-controlled write to a memory 
or I/O port address. 


Specialized logic circuits in the DMA are 
dedicated to the various functions of external 
bus interfacing, internal bus control, byte 
matching, byte counting, periodic pulse 
generation, CPU interrupts, bus requests, and 
address generation. A set of twenty-one 
writable control registers and seven readable 
status registers provides the means by which 
the CPU governs and monitors the activities of 
these logic circuits. All registers are eight bits 
Wide, with double-byte information stored in 
adjacent registers. The two address counters 
(two bytes each) for Ports A and B are buffered 
by the two starting addresses. 
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Figure 6. Block Diagram 
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The 21 writable control registers are 
organized into seven base-register groups, 
most of which have multiple registers. The 
base registers in each writable group contain 
both control/command bits and pointer bits 
that can be set to address other registers within 
the group. The seven readable status registers 
have no analogous second-level registers. 
The registers are designated as follows, 
according to their base-register groups: 


WRO-WR6 - 
Write Register groups 0 


through 6 (7 base registers plus 14.associ- 
ated registers) 
RRO-RR6 - 
Read Registers 0 through 6 


Writing to a register within a write-register 
group involves first writing to the base 
register, with the appropriate pointer bits set, 
then writing to one or more of the other 
registers within the group. All seven of the 
readable status registers are accessed sequen- 
tially according to a programmable mask con- 
tained in one of the writable registers. The sec- 
tion entitled "Programming" explains this in 
more detail. 
A pipe lining scheme is used for reading data 
in. The programmed block length is the 
number of bytes compared to the byte counter, 
which increments at the end of each cycle. In 
searches, data byte compariso'ns with the 
match byte are made during the read cycle of 
the next byte. Matches are, therefore, dis- 
covered only after the next byte is read in. 
In multiple-DMA configurations, i'riterrupt- 


request daisy chains are prioritized by the 
order in which their IEI and IEO lines are con, 
nected (Zilog Application Note 03-0041-01, The 
Z-80 Family Program Interrupt Structure). !he 
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system bu's, however, may not be pre-empted. 
Any DMA that gains access to the system bus 
keeps the bus until it is finished. 
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Figure 7. Multiple-DMA Interconnection to the Z-80 CPU 
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Programming 
The Z-80 DMA has two programmable fun- 
damental states: (1) an enabled state, in which 
it can gain 'control of the system buses and 
direct the transfer of data between ports, and 
(2) a disabled state, in which it can initiate 
neither bus requests nor data transfers. When 
the DMA is powered up or reset by any means, 
it is automatically placed into the disabled 
state. Program commands can be written to it 
by the CPU in either state, but this auto- 
matically puts the DMA in the disabled state, 
which is maintained until an enable command 
is issued by the CPU. The CPU must program 
the DMA in advance of any data search or 
transfer by addressing it as an I/O port and 
sending a sequence of control bytes using an 
Output instruction (such as OTIR for the 
Z-80 CPU). 


Writing. Control or command bytes are writ- 
ten into one or more of the Write Register 
groups (WRO-WR6) by first writing to the base 
register byte in that group. All groups have 
base registers and most groups have additional 
associated registers. The associated registers 
in a group are sequentially accessed by first 
writing a byte to the base register containing 
register-group identification and pointer bits 
(l's) to one or more of that base register's 
associated registers. 
This is illustrated in Figure 8b. In this 
figure, the sequence in which associated 
registers within a group can be written to is 
shown by the vertical position of the associated 
registers. For example, if a byte written to the 
DMA contains the bits that identify WRO (bits 
DO, D I and D7), and also contains l's in the 
bit positions that point to the associated "Port 
A Starting Address (low byte)" and "Port A 
Starting Address (high byte)," then the next 
two bytes written to the DMA will be stored in 
these two registers, in that order. 


Reading. The Read Registers (RRO-RR6) are 
read by the CPU by addressing the DMA as an 
I/O port using an Input instruction (such as 
INIR for the Z-80 CPU). The readable bytes 
contain DMA status, byte-counter values, and 
port addresses since the last DMA reset. The 


Read Register 0 


0, D. Os 0, 0 3 0, 0, Do 
1 X 1 X 1 I 1 1 xiii STATUS BYTE 
Iii I I 
1 = DMA TRANSFER HAS OCCURRED 
a = READY ACTIVE 
a = INTERRUPT PENDING 
a = MATCH FOUND 
a = END OF BLOCK 


Read Register 1 


II....-II....-II....-IL....-JIL....-JIL....-JL....-J-...II BYTE COUNTER (HIGH BYTE) 


registers are always read in a fixed sequence 
beginning with RRO and ending with RR6. 
However, the register read in this sequence is 
determined by programming the Read Mask in 
WR6. The sequence of reading is initialized by 
writing an Initiate Read Sequence or Set Read 
Status command to WR6. After a Reset DMA, 
the sequence must be initialized with the 
Initiate Read Sequence command or a Read 
Status command. The sequence of reading all 
registers that are not excluded by the Read 
Mask register must be completed before a new 
Initiate Read Sequence or Read Status 
command. 


Fixed-Address Programming. A special cir- 
cumstance arises when programming a desti- 
nation port to have a fixed address. The load 
command in WR6 only loads a fixed address to 
a port selected as the source, not to a port 
selected as the destination. Therefore, a fixed 
destination address must be loaded by tem- 
porarily declaring it a fixed-source address 
and subsequently declaring the true source as 
such, thereby implicitly making the other a 
destination. 
The following example illustrates the steps in 
this procedure, assuming that transfers are to 
occur from a variable-address source (Port A) 
to a fixed-address destination (Port B): 


1. Temporarily declare Port B as source in 


WRO. 


2. Load Port B address in WR6. 


3. Declare Port A as source in WRO. 


4. Load Port A address in WR6. 


S. Enable DMA in WR6. 


Figure 9 illust~ates a program to transfer 
data from memory (Port A) to a peripheral 
device (Port B). In this example, the Port A 
memory starting address is 10S0H and the Port 
B peripheral fixed address is OSH. Note that· 
the data flow is I 00 1 H bytes-one more than 
specified by the block length. The table of 
DMA commands may be stored in consecutive 
memory locations and transferred to the DMA 
with an output instruction such as the Z-80 
CPU's OTIR inst~uction. 


Read Register 2 


L..I ....J....I ....J....I ....J....I -"-I _IL....-J ___ :....-..II BYTE COUNTER (LOW BYTE) 


Read Register 3 


11....-11....-1....1 _II......IL....-JI~ ___ -...II PO,RT A ADDRESS COUNTER (LOW BYTE) 


Read Register 4 


11...-1....1 -1-1 -1-1 _IL....-JI~L....-J--II PORT A ADDRESS COUNTER (HIGH BYTE) 


Read Register 5 


II...-II...-II....-I'--IIL....-JIL....-JL....-J-...II PORT B ADDRESS COUNTER (LOW BYTE) 


Read Register 6 


LI -1-1 -1-1 -1-1 .....1.-1 -.:IL--IL....-J--II PORT B ADDRESS COUNTER (HIGH BYTE) 


Figure 8a. Read Registers 
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Programming 
(Continued) 


Wrlle Register 0 Group 


0, 0, 0, D. 0, 0, 0, Do 
I 0 1 1 1 1 1 1 1 I BASE REGISTER BYTE 


I 


! 
! 
DO NOT USE 
o 1" TRANSFER 
1 0" SEARCH 
1 1" SEARCHITRANSFER 
0" PORT B -PORT A 
1 = PORT A -PORT B 


.--....... ,.......,..........,......,..-..,..-...,.---, PORT A STARTING ADDRESS 
L..-...................... -'--'--'-........... (LOW BYTE) 


r-...,..-I-,-J~L..r-...,......,...--r....., PORT A STARTING ADDRESS 


L-J...,.~...L-...L-...I--...I---L..-J (HIGH BYTE) 


.--....... ,.........,..-..,.--..,.--...,.--...,.---, BLOCK LENGTH 
L..-"-rJ...-.L-...L--'--'--'--' (LOW BYTE) 


....-....... ..--..--..--..,..-..,.......,.---, B LOCK LEN GTH 
L-J...-..I.-...L-...L-..J......I---'-..... (HIGH BYTE) 


Write Register 1 Group 


0, 015 Os 0, 0] 02 
D1 00 
I 0 1 1 1 1 11 1 0 1 0 I BASE REGISTER BYTE 


I 1 1" PORT A IS MEMORY 


1 = PORT A IS 110 
o 
0 
= PORT A ADDRESS DECREMENTS 
o 
1 
= PORT A ADDRESS INCREMENTS 


~ 
~ I = PORT A ADDRESS FIXED 


~'----l---'---l..---'---'--'--"'" PORT A VARIABLE TIMING BYTE 


WR ENDS V. CYCLE EARLY =! I 
I 11 1 = CYCLE LENGTH = 4 
Ali ENDS 'fa CYCLE EARLY = 0 
0 1" CYCLE LENGTH a 3 
MREQ ENDS 'fa CYCLE EARLY" 0 
1 
0 = CYCLE LENGTH .. 2 
1 
1 = DO NOT USE 
o " l"OiiQ ENDS 'I. CYCLE EARLY 


Write Register 2 Group 


0, D. 0, D. 0, 0, 0, Do 
I 0 1 1 1 1 1 0 1 0 1 0 I BASE REGISTER BYTE 


I 1 1" PORT B IS MEMORY 


1 " PORT B IS 110 
o 
0 = PORT B ADDRESS DECREMENTS 
o 
1 
"PORT B ADDRESS INCREMENTS 


~ 
~ I- PORT B ADDRESS FIXED 


L-..I.-...L-..J......l-...I--...J-........ -J PORT B VARIABLE TIMING BYTE 


Wii ENDS 'I. CYCLE EARLY,,! I I 11 !" CYCLE LENGTH" 4 
Iili EN OS 'I. CYCLE EARLY = 0 
0 
1 = CYCLE LENGTH .. 3 
~ 
ENDS 'I. CYCLE EARLY a 0 
1 
0" CYCLE LENGTH" 2 
1 
1 
DO NOT USE 
0" Rilm ENDS Va CYCLE· EARLY 


Write Register 3 Group 


0, 0, 0, D. 0, 0, 0, Do 
11 1 1 1 
1 1 0 , 0 1 BASE REGISTER BYTE 


DMA ENABLE a J I 
INTERRUPT ENABLE" 1 
J " STOP ON MATCH 


L-...L--'-~""""""""-'-~"'" 
MASK BYTE (0 a COMPARE) 


I--'--'--J. ........ --,O--'-............. MATCH BYTE 


Write Register 4 Group 


0, 0, 0, D. 0, 0, 0, Do 
11 1 1 1 1 I 1 0 11 I BASE REGISTER BYTE 


BYTE J 1 
CONTINUOUS" 0 
1 


BURST" 1 
0 
DO NOT PROGRAM .. 1 
1 


...-.,...-..,........-L..,........,....t...,.--...,...-. PORT B STARTING ADDRESS 
L-..I.-...L-..l-,-..l..y...J-..J--L.....J (LOW BYTE) 


...-.,...-..,..-...-L..,........,.--...,.--...,...-. PORT B STARTING ADDRESS 
L-..I.-...L-..l-,-...l-..J.....-L..-L.....J (HIGH BYTE) 


L..-~~~~~~--' 
INTERRUPT CONTROL BYTE 


L.....J--J.-.I. ......... --'---'-......L..-J PULSE CONTROL BYTE 


1--'--'-.1.--'---'---1-............... INTERRUPT VECTOR 
I I 
VECTOR IS AUTOMATICALLY {O 0 "INTERRUPT ON ROY 
MODIFIED AS SHOWN 
0 
1 
"INTERRUPT ON MATCH 


ONLY IF "STATUS 
1 
0 
"INTERRUPT ON END OF BLOCK 


AFFECTS VECTOR" BIT IS SET 
1 
1 
"INTERRUPT ON MATCH 
AND END OF BLOCK 


Write RegisterS Group 


0, D. 0, D. 0, 0, 0, Do 
11 1 0 1 , 1 1 0 11 , 0 I BASE REGISTER BYTE 


II I " 
READY ACTIVE LOW 
1~ READY ACTIVE HIGH 
O .. CEONLY 
1 = CElWAIT MULTIPLEXED 
o .. STOP ON END OF BLOCK 
1 = AUTO RESTART ON END OF BLOCK 


Write Register 6 Group 


0, D. 0, D. 0, 0, 0, Do 
11 1 I 1 1 I 11 11 1 
BASE REGISTER BYTE 


I I I I I HEX COMMAND NAME 
0= C3 = RESET 
1 = C7 = RESET PORT A TIMING 
o " CB = RESET PORT B TIMING 


1 = CF = LOAD 
o = 03 = CONTINUE 


1 = AF = DISABLE INTERRUPTS 
o ~ AB " ENABLE INTERRUPTS 
o = A3 = RESET AND DISABLE INTERRUPTS 
1 = B7 = ENABLE AFTER RETI 


1 = BF = READ STATUS BYTE 
o = 8B = REINITIALIZE STATUS BYTE 


o 
1 
0 
0 
1 = A7 = INITIATE READ SEQUENCE 


o 
1 
1 
0 
0 = B3 = FORCE READY 


1 = 87 = ENABLE DMA 
o = 83 = DISABLE DMA 
r- 0 1 1 1 0 = BB = READ MASK FOLLOWS 
Llc"," 1 I I 1 1 I I READ MASK (1 = ENABLE) 
IIIII ~STATUSBYTE 
~~i~ gg~~i~= l~?~ BBYYW) 
• 
PORT A ADDRESS (LOW BYTE) 
PORT A ADDRESS (HIGH BYTE) 
PORT B ADDRESS (LOW BYTE) 
PORT B ADDRESS (HIGH BYTE) 


Figure ab. Write Registers 
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~ 
w 
~ 
6 
W 
w 


c.u 
CJ1 


Comments 
07 
06 
05 
04 


WRO sets DMA to receive 
a 
1 
1 
1 
block length, Port A start- 
Block Length 
Block Length 
Port A 
ing address and temporarily 
Upper 
Lower 
Upper 
sets Port B as source. 
Follows 
Follows 
Address 
Follows 


Port A address (lower) 
a 
1 
a 
1 


Port A address (upper) 
a 
a 
a 
1 


Block length (lower) 
0 
a 
a 
a 


Block length (upper) 
a 
a 
a 
1 


WR1 defines Port A as 
a 
a 
a 
1 
memory with fixed 
No Timing 
Address 
Address 
incrementing address. 
Follows 
Changes 
Increments 


WR2 defines Port B as 
a 
a 
1 
0 


peripheral with fixed 
No Timing 
Fixed 
address. 
Follows 
Address 


WR4 sets mode to Burst, 
1 
1 
a 
a 
sets OMA to expect Port B 
No Interrupt 


address. 
Burst Mode 
Control Byte 
Follows 


Port B address (lower) 
a 
a 
a 
a 


WR5 sets Ready active High. 
1 
0 
a 
0 


No Auto 
No Wait 
Restart 
States 


WR6 loads Port B address 
1 
1 
a 
0 


and resets block counter.* 


WRO sets Port A as source. * 
a 
a 
a 
a 
No Address or Block 
Length Bytes 


WR6 loads Port A address 
1 
1 
a 
a 
and resets block counter. 


WR6 enables OMA to start 
1 
a 
0 
a 
operation. 


-- 
-- 
- 
--- 
--- ------ ------ 
_._- 
'----- 
- 


NOTE: The actual number of bytes transferred is one more than specified by the block length. 
*These entries are necessary only in the case of a fixed destination address. 


03 


1 


Port A 
Lower 
Address 
Follows 


a 
a 
a 
a 


a 


Port is 
Memory 


1 


Port is 


110 


a 
No Upper 
Address 


a 


1 


ROY 


Active High 


1 


a 


1 


a 


Figure 9, Sample DMA Program 


\ 


02 
01 
Do 
a 
a 
I 
1 


B~A 
Temporary 
Transfer, No Search 
for 
Loading B 
Address* 
a 
a 
0 


a 
a 
a 
a 
a 
a 
a 
a 
a 


1 
a 
a 


a 
1 
a 


1 
a 
1 


Port BLower 
Address 
Follows 


1 
a 
1 


a 
1 
a 


1 
1 
1 


1 
0 
1 
A ----..B 
Transfer, No Search 


1 
1 
1 


1 
1 
1 


-- 
-- 
'--- 
-- 
-- 


vEla 081 


HEX 


79 


50 


10 


00 


10 


14 


28 


C5 


05 


8A 


CF 


05 


CF 


87 


......... ~ 
0 ... 
o 0 
~lQ 
::::3 
§ 8 
~B 
-6' 
lQ 


Inactive 
State Timing 
(DMA as CPU 
Peripheral) 


Active State 
Timing 
(DMA as Bus 
Controller) 
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In its disabled or inactive state, the DMA is 
addressed by the CPU as an 1/0 peripheral for 
write and read (control and status) operations. 
Write timing is illustrated in Figure 10. 
Reading of the DMA's status byte, byte 


, counter or port address counters is illustrated 


\ 


C:~~1----- 
lORa 


WR 
----- 


Do-D7 -_-1-_--+__ 
. 


Figure 10. CPU-to-DMA Write Cycle 


Default Read and Write Cycles. By default, 
and after reset, the DMA's timing of read and 
.write operations is exactly the same as the 2-80 
CPU's timing of read and write cycles for 
,memory and 1/0 peripherals, with one excep- 
tion: during a read cycle, data is latched on 
the falling edge of T3 and held on the data bus 
across the boundary between read and write 
cycles, through the end of the following write 
cycle. 
Figure 12 illustrates the timing for memory- 


to-I/O port transfers and Figure 13 illustrates 
I/O-to-memory transfers. Memory-to-memory 
and I/O-to-I/O transfer timings are simply per- 
mutations of these diagrams. 
The default timing uses three T -cycles for 
memory transactions and four T -cycles for 1/0 
transactions, which include one automatically 


in Figure 11. These operations require less 
than three T-cycles. The CE, 'IORQ and 
RD lines are made active over two rising edges 
of CLK, and data appears on the bus approx- 
imately one T-cycle after they become active. 


Figure 11. CPU-to-DMA Read Cycle 


inserted wait cycle between T2 and T3. If the 
CE/WAIT line is programmed to act as a 
WAIT line during the DMA's active state, it is 
sampled on the falling edge of T 2 for memory 
transactions and the falling edge of T w for 1/0 
transactions. If CE/WAIT is Low during this 
time another T -cycle is added, during which 
the CE/,WAIT line will again be sampled. The 
duration of transactions can thus be indef- 
initelyextended. 
Variable Cycle and Edge Timing. The 2-80 
DMA's default operation-cycle length for the 
source (read) port and destination (write) port 
can be independently programmed. This 
variable-cycle feature allows read or write 
cycles consisting of two, three or four T-cycles 
(more if Wait cycles are inserted), thereby 
increasing or decreasing the speed of all 
signals generated by the DMA. In addition, 


I-MEMORY READ _1 .... ----1/0 WRITE ---- 
.. 1 
I 
T, 
I 
T2 
I 
T3 
T, 
T2 
Tw 
T3 


eLK 


Ao-A15 


READ { 


.. mEa 


RD 


WROTE { 


lona 


wn 


Do-D7 


CElWAIT 


Figure 12. Memory-to-I/O Transfer 
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Active State' 
Timing 
(DMA as Bus 
Controller) 
(Continued) 


, .... ----110 READ ---_ 


Tl 
T2 


eLK 


Ao-A15 
!X 
I 
I 


~.{ 


IORQ 


RO 


\ 
I 


'- 
I 


00-07 
~ 
110 DRIVES DATA 
, 


T 
\ 
DMA DRIVES DATA BUS 


WIDTE{ 


UREQ 


WR 


r - 
\ 


W - 
'- 
- ~-- .... --r;J rt --- ---iJ rt ----- 
CEJWAIT 
.... --~-- 
--- --- 
--- 


Figure 13. 1I0-to-Memory Transfer 


the trailing edges of the IORQ, MREQ, RD and 
WR signals can be independently terminated 
one-half cycle early. Figure 14 illustrates this. 
In the variable-cycle mode, unlike default 
timing, IORQ comes active one-half cycle 
before MREQ, RD and WR. CE/WAIT can be 
used to extend only the 3 or 4 T-cycle variable 
. memory cycles and only the 4-cycle variable 
I/O cycle. The CE/WAIT line is sampled at the 
falling edge of T2 for 3- or 4-cycle memory 
cycles, and at the falling edge of T3 for 4-cycle 
1/0 cycles. 
During transfers, data is latched on the 
clock edge causing the rising edge of RD and 
held through the end of the write cycle. 


I T, I T, I T, I T. I 


CLK SUL..JLrUL 
~ 
""-~-t""- 


&0-&.. 
L_ L_ ',-_ 
.ORQ' 
r-r-I I 
-- 


~R~ -----"l 
r -r--,- 
-,- 
- - 
RD, WR 
\.--.L....L-...L- 
t 
t . t· 
2·CYCLE 
3·CYCLE 
,,·CYCLE 
EARLY END EARLY END EARLY END 


Figure 14. Variable-Cyclo and Edge Timing 


Bus Requests. Figure 15 illustrates the bus 
request and acceptance timing. The RDY line, 
which may be programmed active High or 
Low, is sampled on every rising edge of CLK. 
If it is found to be active, and if the bus is not 
in use by any other device, the follOWing rising 
edge of CLK drives BUSREQ low. After receiv- 
~ 
BUSREQ the CPU acknowledges on the 
BAI input either directly or through a 
multiple-DMA daisy chain. When a Low is 
detected on BAI for two consecutive rising 
edges of CLK, the DMA will begin transferring 
data on the next rising edge of CLK. 


CLK 


- - 
- 
- - - 
- r!----.,'!-,,J 
iii ______ --1 


D"A 
INACTIVE 


Figure 15. Bus Request and Acceptance 


D'" 
ACTIVE 
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Bus Release Byte-at-a-Time. Irt~yte-at-a­ 
Time mode, BUSREQ is brought High-on the 
rising, edge of CLK prior to the end of each 
read cycle (search-only) or write cycle 
(transfer and transfer/search) as illustrated in 
Figure 16. This is done regardless of the state 
of RDY. There is no possibility of confusion 
when a 2-80 CPU is used since the CPU 
cannot begin an operation until the following 
T-cycle. Most other CPUs are not bothered by 
this either, although note should be taken of it. 
The next bus reguest for the next byte will 
come after both BUSREQ and BAI have 
returned High. 
Bus Release at End of Block. In Burst and 
Continuous modes, an end of block causes 
BUSREQ to go High usually on the same rising 
edge of CLK in which the DMA completes the 
transfer of the data block (Figure 17). The last 
byte i~ the block is transferred even if RDY 
goes inactive before completion of the last byte 
transfer. 


Bus Release on Not Ready. In Burst mode, 
when RDY goes inactive it causes BUSREQ to 
go High on the next rising edge of CLK after 
the completion of its current byte operation 
(Figure 18). The action on BUSREQ is thus 
somewhat delayed from action on the RDY 
line. The DMA always completes its current 
byte operation in an orderly fashion before 
releasing the b=u..",.s."..,. ==-== 


By contrast, BUSREQ is not released in 
Continuous mode when RDY goes inactive. 


CLK~1....r1.JLJLJL 
I~. ____ -- 


BUSREQ 
• 
I 


B.ii 
I 
J 
___ 
--HI (,CJ 


RDY 


I' 
. 


DMA ACTIVE _\- DMA INACTIVE 


Figure 16. Bus Release (Byte-at-a-Time Mode) 


ACTIVE 


_CTlVE 
~~--~------- 


L~CURRENT BYTE~ 
DMA 
r---- 
OPERATION -~I-- INACTIVE 


Figure 18. Bus Release When Not Ready 
(Burst Mode) 


Instead, the DMA idles after completing the 
current byte operation, awaiting an active RDY 
again. 
Bus Release on Match. If the DMA is pro- 
grammed to stop on match in Burst or Con- 
tinuous modes, a match causes BUSREQ to go 
inactive on the next DMA operation, Le., at 
the end of the next read in a search or at the 
end of the follOWing write in a transfer (Figure 
19). Due to the pipelining scheme, matches 
are determined while the next DMA read or 
write is being performed. 
The RDY line can go inactive after the 
matching operation begins without affecting 
this bus-release timing. 
Interrupts. Timings for interrupt acknowledge 
and return from interrupt are the same as tim- 
ings for these in other 2-80 peripherals. Refer 
to 2ilog Application Note 03-0041.-01 (The Z-aD 
Family Program Interrupt Structure). 
Interrupt on RDY (interrupt before request- 
ing bus) does not directly affect the BUSREQ 
line. Instead, the interrupt service routine 
must handle this by issuing the follOWing 
commands to WR6: 
1. Enable after Return From Interrupt (RETD 
Command - 
Hex B7 
2. Enable DMA - 
Hex 87 
3. An RET! instruction that resets the 
Interrupt Under Service latch in the 
2-80 DMA~ 


RDY 


RDY 


BUSREQ 


Figure 17. Bus Release at End of Block 
(Burst and Continuous Modes) 


rc 


INACTIVE 


--------~.~----------~:~----~ 
f-- 
BYTEA __ 
-;'~I_' _ 
8YTEn+1 
READ IN 
READ IN 


AND 
MATCH FOUND 


ON BYTE" 
Figure 19. Bus Release on Match 
(Burst and Continuous Modes) 
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Absolute 
Maximum 
Ratings 


Test 
Conditions 


DC 
Charac- 
teristics 


Capacitance 


8085-0209 


Operating Ambient 
Temperature Under Bias ... As Specified Under 


Ordering Information. 
Storage Temperature ........ -65°e to + 150 
0e 


Voltage On Any Pin with 
Respect to Ground .......... -0.3 V to + 7.0 V 
Power Dissipation .................... 1.5 W 


The characteristics below apply for the 
following test conditions, unless otherwise 
noted. All voltages are referenced to GND 
(0 V). Positive current flows into the refer- 
enced pin. Available operating temperature 
ranges are: 


C S* = ooe to + 70oe, 


+4.75 V =:; Vee =:; "!-5.25 V 


EJ E* = - 40 
0e to + 85°e, 
+4.75 V =:; Vee =:; +5.25 V 


EJ M* = -55°e to + l25°e, 
+4.5 V =:; Vee =:; +5.5 V_ 


·See Ordering Information section for package 
temperature range and product number. 


Symbol 
Parameter 


VILe 
Clock Input Low Voltage 


VIHe 
Clock Input High Voltage 


VIL 
Input Low Voltage 


VIH 
Input High Voltage 


VOL 
Output Low Voltage 


VOH 
Output High Voltage 


Icc 
Power Supply Current 


2-80 DMA 
2-80A DMA 


ILl 
Input Leakage Current 


ILO 
3-State Output Leakage Current in Float 


ILD 
Data Bus Leakage Current in Input Mode 


Stresses greater than those listed under Absolute Maxi- 
mum Ratings may cause permanent damage to the device. 
This is a stress rating only; operation of.the device at any 
condition above those indicated in the operational sections 
of these specifications is not implied. Exposure to absolute 
maximum rating conditions for extended periods may affect 
device reliability. 


All ac parameters assume a load capacitance 
of 100 pF max. Timing references between two 
output signals assume a load difference of 50 
pF max. 


+5V 


2.1K 


Min 
Max 
Unit Test Condition 


-0.3 
0.45 
V 


Vee-·6 
5.5 
V 


-0.3 
0.8 
V 


2.0 
5.5 
V 


0.4 
V 
loL = 3.2rnA for BUSREQ 
IOL = 2.0 rnA for- all others 


2.4 
V 
IOH = 250 JlA 


150 
rnA 


200 
rnA 


10 
~ VIN = 0 to Vee 


±1O 
JlA 
VOUT = 0.4 V to Vee 
±10 
JlA 
OsVINsVec 


Vee = 5 V ± 5% unless otherwise specified, over speCified temperature range. 


Symbol 
Parameter 
Min 
Max 
Unit 
Test Condition 


C 
Clock Capacitance 
35 
pF 
Unmeasured Pins 


CIN 
Input Capacitance 
5 
pF 
Returned to Ground 


COUT 
Output Capacitance 
10 
pF 


Over specified temperature range; f = I MHz 
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Inactive 
Z-80 DMA 
Z-80A DMA 


State 
Number Symbol 
Parameter 
Min Max 
Min Max 
Unit 
AC 
Character- 
TcC 
Clock Cycle Time 
400 
4000 
250 
4000 
ns 
istics 
2 
TwCh 
Clock Width (High) 
170 
2000 
110 
2000 
ns 
3 
TwCl 
Clock Width (Low) 
170 
2000 
110 
2000 
ns 
4 
TrC 
Clock Rise Time 
30 
30 
ns 
- 
5-TfC 
Clock Fall Time 
30 
30--ns- 


6 
Th 
Hold Time for Any Specified Setup Time 
0 
0 
ns 
7 
TsC(Cr) 
IORQ, WR, CE I to Clock , Setup 
280 
145 
ns 
8 
TdDO(RDf) 
RDl to Data Output Delay 
500 
380 
ns 
9 
TsWM(Cr) 
Data In to Clock' Setup (WR or Ml) 
50 
50 
ns 
-10- TdCf(DO) --IORQ I to Data Out Delay (INTA Cycle) 
340 
160--ns- 


11 
TdRD(Dz) 
RD , to Data Float Delay (output buffer 
disable) 
160 
110 
ns 
12 
TsIEI(lORQ) 
IEII to IORQ I Setup (INTA Cycle) 
140 
140 
ns 
13 
T dIEOr(lElr) 
lEI I to lEO I Delay 
210 
160 
ns 
14 
T dIEOf(lEIf) 
lEI I to lEO I Delay 
190 
130 
ns 
_15_TdMl(1EO)_Ml I to lEO I Delay (interrupt just prior to 


Mll) 
300 
190 
ns 
16 
TsMlf(Cr) 
Ml I to Clock I Setup 
210 
90 
ns ' 


17 
TsMlr(C£) 
Ml I to Clock I Setup 
20 
-10 
ns 
18 
TsRD(Cr) 
RD I to Clock I Setup (Ml Cycle) 
240 
115 
ns 
19 
Tdl(lNT) 
Interrupt Cause to INT I Delay (INT generated 
only when DMA is inactive) 
500 
500 
ns 


_20 _ TdBAlr(BAOr)_BAI 'to BAO , Delay 
200 
150--ns_ 


21 
T dBAIf( BAO£) BAI I to BAO I Delay 
200 
150 
ns 
22 
TsRDY(Cr) 
RDY Active to Clock I Setup 
150 
100 
ns 


NOTE: 
I, Negative minimum setup values mean that the lirst-mention~d event can come alter the second-mentioned event. 
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Inactive 
State 
AC 
Character- 
istics 
CLK 
(Continued) 


00-07 


ii1 


lEI 


lEO 


INT 


INTERRUPT 
CONDITION 


DAI 


BAD 


ROY 


NOTE: 


ACTIVE 


INACTIVE 


"1" 
"0" 
CLOCK 
4.2 V 0.' V 


OUTPUT 
2.0 V 0.8 V 


INPUT 
2.0 V 0.1 V 


Signals in this diagram bear no relation to one another unless specifically noted as a numbered item. 
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Active 
Z-80 DMA 
Z-80A DMA 
State 
Number Symbol 
Parameter 
Min{ns) 
Max{ns) 
Min{ns) 
Max{ns) 


AC 
Character- 
TcC 
Clock Cycle Time 
400 
250 


istics 
2 
TwCh 
Clock Width (High) 
180 
2000 
110 
2000 


3 
TwC1 
Clock Width (Low) 
180 
2000 
110 
2000 


4 
TrC 
Clock Rise Time 
30 
30 


5-TfC 
Clock Fall Time 
30 
30- 


6 
TdA 
Address Output Delay 
145 
110 


7 
TdC(Az) 
Clock t to Address Float Delay 
110 
90 


8 
TsA(MREQ) Address to MREQ I Setup (Memory Cycle) (2) + (5)-75 
(2) + (5)-75 


9 
TsA(IRW) 
Address Stable to IORQ, RD, WR I Setup 


(I/O Cycle) 
(1)-80 
(1)-70 
*10-TdRW(A)-RD, WR t to Addr. Stable Delay 
(3) + (4)-40 
(3) + (4)-50 


*11 
TdRW(Az) 
RD, WR t to Addr. Float 
(3) + (4)-60 
(3) + (4)-45 


12 
TdCf(DO) 
Clock I to Data Out Delay 
230 
150 


* 13 
TdCr(Dz) 
Clock t to Data Float Delay (Write Cycle) 
90 
90 


14 
TsDI(Cr) 
Data In to Clock t Setup (Read cycle when 
rising edge ends read) 
50 
35 


15 -TsDl(Cf) - 
Data In to Clock I Setup (Read cycle when 
falling edge ends read) 
60 
50 


*16 
TsDO(WfM) Data Out to WR I Setup (Memory Cycle) 
(1)-210 
(1)-170 


17 
TsDO(WfI) 
Data Out to WR I Setup (I/O cycle) 
100 
100 


*18 
TdWr(DO) 
WR t to Data Out Delay 
(3) + (4)-80 
(3) + (4)-70 


19 
Th 
Hold Time for Any Specified Setup Time 
0 
0 


20-TdCr(Mf)-Clock I to MREQ I Delay 
100 
85- 


21 
TdCf(Mf) 
Clock I to MREQ I Delay 
100 
85 
22 
TdCr(Mr) 
Clock I to MREQ I Delay 
100 
85 
23 
TdCf(Mr) 
Clock I to MREQ t Delay 
100 
85 
24 
TwMl 
MREQ Low Pulse Width 
(1)-40 
(1)-30 
*25-TwMh--MREQ High Pulse Width 
(2) + (5)-30 
(2) + (5)-20 


26 
TdCf(lf) 
Clock I to IORQ I Delay 
110 
85 


27 
TdCr(lf) 
Clock I to IORQ I Delay 
90 
75 
28 
TdCr(lr) 
Clock t to IORQ t Delay 
100 
85 


*29 
TdCf(lr) 
Clock I to IORQ I Delay 
110 
85 
30-TdCr(Rf)-Clock t to RD I Delay 
100 
85- 


31 
TdCf(Rf) 
Clock I to RD I Delay 
130 
95 


32 
TdCr(Rr) 
Clock t to RD I Delay 
100 
85 


33 
TdCf(Rr) 
Clock I to RD I Delay 
110 
85 


34 
TdCr(Wf) 
Clock I to WR I Delay 
80 
65 
35-TdCf(Wf)-Clock I to WR I Delay 
90 
80- 


36 
TdCr(Wr) 
Clock I to WR t Delay 
100 
80 


37 
TdCf(Wr) 
Clock I to WR I Delay 
100 
80 


38 
TwWl 
WR Low Pulse Width 
(1)-40 
(1)-30 


39 
TsWA(Cf) 
WAIT to Clock I Setup 
70 
70 


40-TdCr(B)-Clockl to BUSREQ Delay 
150 
100- 


41 
TdCr(lz) 
Clock t to IORQ, MREQ, RD, WR Float 
Delay 
100 
80 


NOTES: 
I. Numbers in parentheses are other parameter·numbers in this taQle; their values should be substituted in equations. 
2. All equations imply DMA default (standard) liming. 
3. Data must be enabled onto data bus when RD is active. 
4. Asterisk (') before parameter number means the parameter is not illustrated in the AC Timing Diagrams. 
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eLK 


Ao-At5 


{ 


INPUT 


Do-D7 
OUTPUT --+-oH----++------++-----+----H...,. 


MREQ 


iii) 


WR 


IORQ 


iii) 


WR 


WAIT 


BUSREQ 


NOTE: 
Signals in this diagram bear no relation to one another unless specifically noted as a numbered item. 


N 
00 
0 
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Ordering 
Product 
Package/ 
Product 
Package/ 
Information 
Number 
Temp 
Speed 
Description 
Number 
Temp 
Speed 
Description 


Z8410 
CE 
2.5 MHz 
ZSO DMA (40~pin) 
Z8410 
PE 
2.5 MHz 
Z80 DMA (40-pin) 


Z8410 
CM 
2.5 MHz 
Same as above 
Z8410 
PS 
2.5 MHz 
Same as above 


Z8410 
CS 
2.5 MHz 
Same as above 
Z8410A 
CS 
4.0 MHz 
ZSOA DMA (40-pin) 


Z8410 
DE 
2.5 MHz 
Same as above 
Z8410A 
DS 
4.0 MHz 
Same as above 


Z8410 
DS 
2.5 MHz 
Same as above 
Z8410A 
PS 
4.0 MHz 
Same as above 


'NOTES: C = Ceramic, D = Cerdip, P = Plastic; E = -40°C to +85°C, M = -55°C to + 125°C, S = O°C to +70°C. 
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[] Provides a direct interface between Z-80 


microcomputer systems and peripheral 
devices. 


[] Both ports have interrupt-driven handshake 
for fast response. 


[] Four programmable operating modes: byte 
input, byte output, byte inpuUoutput (Port A 
only), and bit inpuUoutput. 


The 2-80 PIa Parallel 1/0 Circuit is a pro- 
grammable, dual-port device that provides a 
TTL-compatible interface between peripheral 
devices and the 2-80 CPU. The CPU config- 
ures the 2-80 PIa to interface with a wide 
range of peripheral devices with no other 
external logic. Typical peripheral devices that 
are compatible with the 2-80 PIa include most 
keyboards, paper tape readers and punches, 
printers, PROM programmers, etc. 


One characteristic of the 2-80 peripheral 
controllers that separates them from other 
interface controllers is that all data transfer 
between the peripheral device and the CPU is 


INTERRUPT { 
CONTROL 


A, 


,.. 


As 


Aa 


A7 


ARDY 


ASTB 


Z·80 PIO 
Bo 


B, 


B2 


B3 


B. 


B5 


Bs 


B7 


BRDY 


BSTB 


Figure 1. Pin Functions 
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September 1983 


II Programmable interrupts on peripheral 
status conditions. 


II Standard 2-80 Family bus-request and 
prioritized interrupt-request daisy chains 
implemented without external logic. 


fl The eight Port Boutputs can drive Dar- 
lington transistors (1.5 rnA at 1.5 V). 


accomplished under interrupt control. Thus, 
the interrupt logic of the PIa permits full use 
of the efficient interrupt capabilities of the 
2-80 CPU during I/O transfers. All logic 
necessary to implement a fully nested interrupt 
structure is included in the PIa. 


Another feature of the PIa is the ability to 
interrupt the CPU upon occurrence of speci- 
fied status conditions in the peripheral device. 
For example, the PIa can be programmed to 
interrupt if any specified peripheral alarm con- 
ditions should occur. This interrupt capability 
reduces the time the processor must spend in 
polling peripheral status. 
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Figure 2. Pin Assignments 
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The Z-80 PIO interfaces to peripherals via 
two independent general-purpose I/O ports, 
designated Port A and Port B. Each port has 
eight data bits and two handshake signals, 
Ready and Strobe, which control data transfer. 
The Ready output indicates to the peripheral 
that the port is ready for a data transfer. 
Strobe is an input from the peripheral that 
indicates when a data transfer has occurred. 


Operating Modes. The Z-80 PIO ports can be 
programmed to operate in four modes: byte 
output (Mode 0), byte input (Mode 1), byte 
input/output (Mode 2) and bit input/output 
(Mode 3). 
In Mode 0, either Port A or Port B can be 
programmed to output data. Both ports have 
output registers that are individually addressed 
by the CPU ; data can be written to either port 
at any time. When data is written to a port, an 
active Ready output indicates to the external 
device that data is available at the associated 
port and is ready for transfer to the external 
device. After the data transfer, the external 
device responds with an active Strobe input, 
which generates an interrupt, if enabled. 
In Mode I, either Port A or Port B can be 
configured in the input mode. Each port has 
an input register addressed by the CPU. When 
the CPU reads data from a port, the PIO sets 
the Ready signal, which is detected by the 
external device. The external device then 
places data on the I/O lines and strobes the 
I/O port, which latches the data into the Port 
Input Register, resets Ready, and' triggers the 
Interrupt Request, if enabled. The CPU can 
read the input data at any time, which again 
sets Ready.- 
Mode 2 is bidirectional and uses Port A, 
plus the interrupts and han jshake signals from 
both PGrts. Port B must be set to Mode 3 and 
masked off. In operation, Port A is used for 
both data input and output. Output operation 
is similar to Mode 0 except that data is allowed 
out onto the Port A bus only when ASTB is 
Low. For input, operation is similar to Mode I, 
except that the data input uses the Port B 
handshake signals and the Port B interrupt (if 
enabled). 
Both ports can be used in Mode 3. In this 
mode, the individual bits are defined as either 
input or output bits. This provides up to eight 
separate, individually defined bits for each 
port. During operation, Ready and Strobe are 


not used. Instead, an interrupt is generated if 
the condition of one input changes, or if all 
inputs change. The requirements for gener.- 
ating an interrupt are defined during the pro- 
gramming operation; the active level is 
specified as either High or Low, and the logic 
condition is specified as either one input active 
(OR) or all inputs active (AND). For example, 
if the port is programmed for active Low 
inputs and the logic function is AND, then all 
inputs at the specified port must go Low to 
generate an interrupt. 
Data outputs are controlled by the CPU and 
can pe written or changed at any time. 


iii Individual bits can be masked off. 
a The handshake signals are not used in 
Mode 3; Ready is held Low, and Strobe is 
disabled. 


I!!I When using the Z-80 PIO interrupts, the 


Z-80 CPU interrupt mode must be set to 
Mode 2. 
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Figure 3. PIO in a Typical zao Family Environment 
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The internal structure of the 2-80 PIO con- 
sists of a 2-80 CPU bus interface, internal con- 
trollogic, Port A I/O logic, Port B I/O logic, 
and interrupt control logic (Figure 4). The 
CPU bus interface logic allows the 2-80 PIO to 
interface directly to the 2-80 CPU with no 
other external logic. The internal control logic 
synchronizes the CPU data bus to the per- 
ipheral device interfaces (Port A and Port B). 
The two I/O ports (A and B) are virtually 
identical and are used to interface directly to 
peripheral devices. 


Port Logic. Each port contains separate input 
and output registers, handshake control logic, 
and the control registers shown in Figure 5. 
All data transfers between the peripheral unit 
and the CPU use the data input and output 
registers. The handshake logic associated with 
each port controls the data transfers through 
the input and the output registers. The mode 
control register (two bits) selects one of the 
four programmable operating modes. 
The control mode (Mode 3) uses the remain- 
ing registers. The input/output control register 
specifies which of the eight data bits in the 
port are to be outputs and enables these bits; 
the remaining bits are inputs. The mask reg- 
ister and the mask control register control 
Mode 3 interrupt conditions. The mask register 
specifies which of the bits in the port are 
active and which are masked or inactive. 


INTERRUPT CONTROL LINES 


The mask control register specifies two 
conditions: first, whether the active state of 
the input bits is High or Low, and second, 
whether an interrupt is generated when any 
one unmasked input bit is active (OR condi- 
tion) or if the interrupt is generated when 
all unmasked input bits are active (AND 
condi tion). 


Interrupt Control Logic. The interrupt control 
logic section handles all CPU interrupt pro- 
tocol for nested-priority interrupt structures. 
Any device's physical location in a daisy-chain 
configuration determines its priority. Two lines 
(lEI and lEO) are provided in each PIO to 
form this daisy chain. The device closest to the 
CPU has the highest priority. Within a PIO, 
Port A interrupts have higher priority than 
those of Port B. In the byte input, byte output, 
or bidirectional modes, an interrupt can be 
generated whenever the peripheral requests a 
new byte transfer. In the bit control mode, an 
interrupt can be generated when the periph- 
eral status matches a programmed value., The 
PIO provides for complete control of nested 
interrupts. That is, lower priority devices may 
not interrupt higher priority devices that have 
no"t had their interrupt service routines com- 
pleted by the CPU. Higher priority devices 
may interrupt the servicing of lower priority 
devices. 


DATA 
OR CONTROL 


} HANDSHAKE 
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PERIPHERAL 
INTERFACE 


Figure 4. Block Diagram 
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If the CPU (in interrupt Mode 2) accepts an 
interrupt, the interrupting device must provide 
an 8-bit interrupt vector for the CPU. This vec- 
tor forms a pointer to a loca Hon in memory 
where the address of the interrupt service 
routine is located. The 8-bit vector from the 
interrupting device forms the least significant 
eight bits of the indirect pointer while the 
I Register in the CPU provides the most signifi- 
cant eight bits of the pointer .. Each port (A and 
B) has an independent interrupt vector. The 
least Significant bit of the vector is automati- 
cally set to 0 within the PIa because the 
pointer must point to two adjacent memory 
locations for a complete 16-bit address. 
Unlike the otherZ-80 peripherals, the PIa 


does not enable interrupts immediately after 
programming. It waits until Ml goes Low (e.g., 
during an opcode fetch). This condition is 
unimportant in the Z-80 environment but might 
not be if another type of CPU is used. 
The PIa decodes the RETI (Return From 


MODE 
CONTROL 
REGISTER 


(2 BITS) 


Interrupt) instruction directly from the CPU 
data bus so that each PIa in the system knows 
at all times whether it is being serviced by the 
CPU interrupt service routine. No other com- 
munication with the CPU is required. 


CPU Bus 110 Logic. The CPU bus interface 
logic interfaces the Z-80 PIa directly to the 
Z-80 CPU, so no external logic is necessary. 
For large systems, however, address decoders 
and/or buffers may be necessary. 
Internal Control Logic. This logic receives the 
control words for each port during program- 
ming and, in turn, controls the operating func- 
tions of the Z-80 PIa. The control logic syn- 
chronizes the port operations, controls the port 
mode, port addressing, selects the read/write 
function, and issues appropriate commands to 
the ports and the interrupt logic. The Z-80 PIa 
does not receive a write input from the CPU; 
instead, the RD, CE, cliS and IORQ signals 
generate the write input internally. 
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Figure S. Typical Port 110 Block Diagram 
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Programming Mode 0, L or 2. (Byte Input, Output, or 
Bidirectional). Programming a port for Mode 
0, I, or 2 requires two words per port. These 
words are: 


A Mode Control Word. Selects the port operating mode 
(Figure 6). This word may be written any time. 


An Interrupt Vector. The Z·80 PIO is designed for use with 
the Z·80 CPU in interrupt Mode 2 (Figure 7). When inter- 
rupts are enabled, the PIO must provide an interrupt 
vector. 
Mode 3. (Bit Input/Output). Programming a 
port for Mode 3 operation requires a control 
word, a vector (if interrupts are enabled), and 
three additional words, described as follows: 


I/O Register Control. When Mode 3 is selected, the mode 
control word must be followed by another control word that 
sets the 110 control register, which in turn defines which 
port lines are inputs and which are outputs (Figure 8). 


107\ 06\ 05\0.\1 11 11 11 I 


I ~ 
IDENTIFIES MODE 
CONTROL WORD 


OON'T CARE 


MODE SELECT 


MODE 0 ('I 
MODE 1 
MODE 2 
MODE 3 


Figure 6. Mode Control Word 
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L IDENTIFIES INTERRUPT 


VECTOR 


'--____ ~~~~;~PPLIEO INTERRUPT 


Figure 7. Interrupt Vector Word 


Figure 8. I/O Register Control Word 
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Interrupt Control Word. In Mode 3, handshake is not 
used. Interrupts are generated as a logic function of the 
input signal levels. The interrupt control word sets the 
logic conditions and the logic levels required for gener- 
ating an interrupt. Two logic conditions or functions are 
available: AND (if all input bits change to the active level, 
an interrupt is triggered), and OR (if anyone of the input 
bits changes to the active level, an interrupt is triggered). 
Bit D6 sets the logic function, as shown in Figure 9. The 
active level of the input bits can be set either High or Low. 
The active level is controlled by Bit D5. 


Mask Control Word. This word sets the mask control 
register, allowing any unused bits to be masked off. If any 
bits are to be masked, then D4 must be set. When D4 is set, 
the next word written to the port must be a mask control 
word (Figure 10). 
Interrupt Disable. There is one other control 
word which can be used to enable or disable a 
port interrupt. It can be used without changing 
the rest of the interrupt control word 
(Figure 11). 


I 071 061 051 0.1 0 11 11 11 I 
III 
L 
:~:i::~~:,~::::, '"'ww, 
o. = 1 MASK WORD FOLLOWS 
05 = 0 ACTIVE LEVEL IS LOW 
05 = 1 ACTIVE LEVEL IS HIGH 
06 = 0 INTERRUPT ON OR FUNCTION 
06 = 1 INTERRUPT ON AND FUNCTION 


L-. ________ ~~ : 
~ :~~~::~:~ ~~::c:~. 


'NOTE: THE PORT IS NOT ENABLED UNTIL 
THE INTERRUPT ENABLE IS FOLLOWED 
BY AN ACTIVE Mi. 


Figure 9. Interrupt Control Word 


MBo-MB7 MASK BITS. A 
BIT IS MONITORED FOR AN 
'------ INTERRUPT IF IT IS 


DEFINED AS AN INPUT AND 
THE MASK BIT IS SET TO O. 


Figure 10. Mask Control Word 


I 071 061 051 0.1 0 I 0 I 1 11 I 
1 
T . c-= IDENTIFIES INTERRUPT 
DISABLE WORD 


DON'T CARE 


07 = 0 INTERRUPT DISABLE 
07 = 1 INTERRUPT ENABLE 


Figure 11. Interrupt Disable Word 
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Ao-A7' Port A Bus (bidirectional, 3-state). 
This 8-bit bus transfers data, status, or control 
information between Port A of the PIO and a 
peripheral device. Ao is the least significant 
bit of the Port A data bus. 
AHOY. Register A Ready (output, active 
High). The meaning of this signal depends on 
the mode of operation selected for Port A as 
follows: 


Output Mode. This signal goes active to indicate that the 
Port A output register has been loaded and the peripheral 
data bus is stable and ready for transfer to the peripheral 
device. 


Input Mode. This signal is active when the Port A input 
register is empty and ready to accept data from the 
peripheral device. 


Bidirectional Mode. This signal is active when data is 
available in the Port A output register for transfer to the 
peripheral device. In this mode, data is not placed on the 
Port A data bus, unless ASTB is active. 


Control Mode. This signal is disabled and forced to a Low 
state. 
ASTB. Port A Strobe Pulse From Peripheral 
Device (input, active Low). The meaning of 
this signal depends on the mode of operation 
selected for Port A as follows: 


Output Mode. The positive edge of this strobe is issued by 
the peripheral to acknowledge the receipt of data made 
available by the PI~. 


Input Mode. The strobe is issued by the peripheral to load 
data from the peripheral into the Port A input register. 
Data is loaded into the PIO when this signal is active. 


Bidirectional Mode. When this signal is active, data from 
the Port A output register is gated onto the Port A bidirec- 
tional data bus. The positive edge of the strobe acknowl- 
edges the receipt of the data. 


Control Mode. The strobe is inhibited internally. 
Bo-B7' Port B Bus (bidirectional, 3-state). This 
8-bit bus transfers data, status, or control 
information between Port B and a peripheral 
device. The Port B data bus can supply 
1.5 rnA at 1.5 V to drive Darlington transistors. 
Bo is the least significant bit of the bus. 
BfA. Port B Or A Select (input, High = B). 
This pin defines which port is accessed during 
a data transfer 'between the CPU and the PIO. 
A Low on this pin selects Port A; a High 
selects Port B. Often address bit Ao from the 
CPU is' used for this selection function. 


BHOY. Register B Ready (output, active High). 
This signal is similar to ARDY, except that in 
the Port A bidirectional mode this signal is 
High when the Port A input register is empty 
and ready to accept data from the peripheral 
device. 
BSTB. Port B Strobe Pulse From Peripheral 
Device (input, active Low). This signal is 
similar to ASTB, except that in the Port A 
bidirectional mode this signal strobes data 
from the peripheral device into the Port A 
input register. 


C/D.Control Or Data Select (input, 
High = C). This pin defines the type of data 
transfer to be performed between the CPU and 
the PIO. A High on this pin during a CPU 
write to the PIO causes the Z-80 data bus to be 
interpreted as a command for the port selected 
by the B/A Select line. A Low on this pin 
means that the Z-80 data bus is being used to 
transfer data between the CPU and the PIO. 
Often address bit Al from the CPU is used for 
this function. 
CEo Chip Enable (input, active Low). A Low 
on this pin enables the PIO to accept com- 
mandor data inputs from the CPU during a 
write cycle or to transmit data to the CPU dur- 
ing a read cycle. This signal is generally 
decoded from four 1/0 port numbers for Ports 
A and B, data, and control. 
CLK. System Clock (input). The Z-80 PIO uses 
the standard single-phase Z-80 system clock. 


00-07. Z-80 CPU Data Bus (bidirectional, 
3-state). This bus is used to transfer all data 
and commands between the Z-80 CPU and the 
Z-80 PIO. Do is the least Significant bit. 
lEI. Interrupt Enable In (input, active High). 
This signal is used to form a priority-interrupt 
daisy chain when more than one interrupt- 
driven device is being used. A High level on 
this pin. indicates that no other devices of 
higher priority are being serviced by a CPU 
interrupt service routine. 
lEO. Interrupt Enable Out (output, active 
High). The lEO signal is the other signal 
required to form a daisy chr..in ~riority scheme. 
It is High only if lEI is High rtnd the CPU is 
not servicing an interrupt from this PIO. Thus 
this signal blocks lower priority devices from 
interrupting while a higher priority device is 
being serviced by its CPU interrupt service 
routine. 
INT. Interrupt Request (output, open drain, 
active Low). When INT is active the Z-80 PIO 
is. requesting an interrupt from the Z-80 CPU. 
IOHQ. Input/Output Request (input from Z-80 
CPU', active Low). 10RQ is used in conjunc- 
tion with BfA, C/O, CE, and RD to transfer 
commands and data between the Z-80 CPU and 
the Z-80 PIO. When CE, RD, and 10RQ are 
active, the port addres1?ed by B/A transfers 
data to the CPU (a read operation). Con- 
versely, when CE and IORQ are active but RD 
is not, the port addressed by B/A is written 
into from the CPU with either data or control 
information, as speCified by cm. Also, if 
10RQ and Ml are active simultaneously, the 
CPU is acknowledging an interrupt; the inter- 
rupting port automatically places its interrupt 
vector on the CPU data bus if it is the highest 
priority device requesting an interrupt. 


Pin 
Description 
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Ml. Machine Cycle (input from CPU, active 
Low). This signal is used as a sync pulse to 
control several internal PIO operations. When 
both the Ml and RD signals are active, the 
Z-80 CPU is fetching an instruction from 
memory. Conversely, when both Ml and 
IORQ are active, the CPU is acknOWledging 
an interrupt. In addition, Ml has two other 
functions within the Z-80 PIO: it synchronizes 


The following timing diagrams show typical 
timing in a 2-80 CPU environment. For more 
precise specifications refer to the composite 
ac timing diagram. 


Write Cycle. Figure 12 illustrates the 
timing for programming the 2-80 PIO 
or for writing data to one of its ports. No 
Wait states are allowed for writing to the 
PIO other than the automatically inserted 
TWA. The PIO does not receive a speci- 
fic' write signal; it internally generates 
its own from the lack of an active 
RD signal. 


Read Cycle. Figure 13 illustrates the timing 
for reading the data input from an external 
device to one of the 2-80 PIO ports. No Wait 
states are allowed for reading the PIO other 
than the automatically inserted TWA. 
Output Mode (Mode 0). An output cycle 
(Figure 14) is always started by the execution 
of an output instruction by the CPU. The WR* 
pulse from the CPU latches the data from the 
CPU data bus into the selected port's output 
register. The WR * pulse sets the Ready flag 
after a Low-going edge of CLK, indicating 
data is available. Ready stays active until the 
positive edge of the strobe line is received, 
indicating that data was taken by the periph- 
eral. The positive edge of the strobe pulse 
generates an INT if the interrupt enable flip- 
flop has been set and if this device has the 
highest priority. 


·WR = RD· CE • C/D • IORQ 


the PIO interrupt logic; when Ml occurs 
without an active RD or IORQ signal, the PIO 
is reset. 


RD. Read Cycle Status (input from Z-80 CPU, 
active Low). If RD is active, or an I/O opera- 
tion is in progress, RD is used with BiA, Ci15, 
CE, and IORQ to transfer data from the Z-80 
PIO to the Z-80 CPU. 
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Figure 12. Write Cycle Timing 
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Figure 13. Read Cycle Timing 


Figure 14. Mode 0 Output Timing 
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Input Mode (Mode I). When STROBE goes 
Low, data is loaded into the selected port input 
register (Figure 15). The next rising edge of 
strobe activates INT, if Interrupt Enable is set 
and this is the highest-priority requesting 
device. The following falling edge of CLK 
resets Ready to an inactive state, indicating 


*RD = RD. CE • C/D· IORQ 


that the input register is full and cannot accept 
any more data until the CPU completes a read. 
When a read is complete, the positive edge of 
RD sets Ready at the next Low-going transition 
of CLK. At this time new data can be loaded 
into the PIO. 


Figure 15. Mode 1 Input Timing 


Bidirectional Mode (Mode 2). This is a com- 
bination of Modes 0 and 1 using all four hand- 
shake lines and the eight Port A I/O lines 
(Figure 16). Port B must beset to the bit mode 
and its inputs must be masked. The Port A 
handshake lines are used for output control 
and the Port B lines are used for input control. 


eLK 


ARDY __________________ -J 


BRDY 


If interrupts occur, Port A's vector will be used 
during port output and Port B's will be used 
during port input. Data is allowed out onto the 
Port A bus only when ASTB is Low. The rising 
edge of this strobe can be used to latch the 
data into the peripheral. 


Figure 16. Mode 2 Bidirectional Timing 
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Timing 
( Continued) 
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Bit Mode (Mode 3). The bit mode does not 
utilize the handshake signals, and a normal 
port write or port read can be executed at any 
time. When writing, the data is latched into 
the output registers with the same timing as the 
output mode (Figure 17). 
When reading the PIO, the data returned to 
the CPU is composed of output register data 
from those port data lines assigned as outputs 
and input register data from those port data 


eLK 


lines assigned as inputs. The input register 
contains data that was present immediately 
prior to the falling edge of RD. An interrupt is 
generated if interrupts from the port are 
enabled and the data on the port data lines 
satisfy the logical equation defined by the 8-bit 
mask and 2-bit mask control registers. How- 
ever, if Port A is programmed in bidirectional 
mode, Port B does not issue an interrupt in bit 
mode and must therefore be polled. 


OAT:~n~ 
X 
DATA WORD 1 
X 
DATA WORD 2 
X'-_________ _ 


,~:: ~~~~~~~-g-~~~~:-:~-\-~>-~~----------~-!~~~{ ___ J~r-------------------- 


00-0 7 -----------------...{~DA:_;;TA;_;;IN;_\.) ----------------- 


• Timing Diagram Refers to Bit Mode Read 
t. DATA WORD 1 PLACED ON BUS 


Figure 17. Mode 3 Bit Mode Timing 


Interrupt Acknowledge Timing. During Ml 
time, peripheral controllers are inhibited from 
changing their interrupt enable status, permit- 
ting the Interrupt Enable signal to ripple 
through the daisy chain. The peripheral with 
lEI High and IEO Low during INTACK places 
a preprogrammed 8-bit interrupt vector on the 
data bus at this time (Figure 18). IEO is held 
Low until a Return From Interrupt (RET!) 
instruction is executed by the CPU while lEI is 
High. The 2-byte RETI instruction is decoded 
internally by the PIO for this purpose. 
' 


Return From Interrupt Cycle. If a 2-80 per- 
ipheral has no interrupt pending and is not 
under service, then its IEO = lEI. If it has an 
interrupt under service (i.e., it has already 
interrupted and received an interrupt acknowl- 
edge) then its IEO is always Low, inhibiting 
lower priority devices from interrupting. If it 
has an interrupt pending which has not yet 
been acknowledged, IEO is Low unless an 
"ED" is decoded as the first byte of a 2-byte 
opcode (Figure 19). In this case, lEO goes 
High until the next opcode byte is decoded, 
whereupon it goes Low again. If the second 
byte of the opcode was a "4D," then the 
opcode was an RET! instruction. 
After an "ED" opcode is decoded, only the 
peripheral device which has interrupted and is 
currently under service has its lEI High and its 


eLK 


lEO 


lEI 


~ri I T, I T, I TIlA I T.. I T. I 


} 


IORQ AND M1 
INDICATE 
INTERRUPT 
ACKNOWLEDGE 
,..--___ INTACK 


Figure 18. Interrupt Acknowledge Timing 


lEO Low. This device is the highest-priority 
device in the daisy chain that has received an 
interrupt acknowledge. All other peripherals 
have IEI = IEO. If the next opcode byte 
decoded is "4D," this peripheral device resets 
its "interrupt under service" condition. 


T, 
T, 
T. 
T, 
T, 
T, 
T. 
T, 
T, 


eLK 
iii1\ 
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Figure 19. Return From Interrupt 
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CLOCK 


CE 
B/i,C/6 


iiD,lORQ 
--------------~~ 


Do-D7 {OUT ----f-----.."Jt----+-------.J. r--II-+-----+---- 


IN 
------------~----,~-----+----------------~ 


lEI 


lEO 


READY 
(ARDY OR BRDY) 


5TRoiiE 


(ASTB OR BSTB) 


MODED 


MODE1 


MODE2 


MODE3 
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Z-BO PIO 
Z-BOA PIO 
Z-BOB PIO[9] 


Min 
Max 
Min 
Max 
Min 
Max 
Number Symbol 
Parameter 
(ns) 
(ns) 
(ns) 
(ns) 
(ns) 
(ns) 
Comment 


1 
TcC 
Clock Cycle Time 
400 
[ 1) 
250 
[ 1) 
1"65 
[ 1) 


2 
TwCh 
Clock Width (High) 
170 
2000 
105 
2000 
65 
2000 


3 
TwCl 
Clock Width (Low) 
170 
2000 
105 
2000 
65 
2000 


4 
TfC 
Clock Fall Time 
30 
30 
20 


5-TrC 
Clock Rise Time 
30 
30 
20 


6 
TsCS(Rl) 
CE, BIA, CIO to RD, 
IORQ I Setup Time 
50 
50 
50 
(6) 


7 
Th 
Any Hold Times for Specified 
Setup Time 
0 
0 
0 
0 


8 
TsR1(C) 
RD, IORQ to Clock t Setup 


Time 
115 
115 
70 


9 -TdR1(DO) --RD, IORQ Ito Data Out Delay 
430 
380 
300 
[2)-- 


10 
TdR1(DOs) 
RD, IORQ t to Data Out Float 
Delay 
160 
110 
70 
r!'.J 


11 
TsD1(C) 
Data In to Clock t Setup Time 
50 
50 
40 
CL = 50 pF 
CO 
(3 


12 
TdIO(DOl) 
IORQ I to Data Out Delay 
~ 
(INTACK Cycle) 
340 
160 
120 
[3) 
fI::!I e 


13 -TsMl(Cr) --MI I to Clock t Setup Time--21O 
90 
70 


14 
TsMl(Cf) 
MI.-Lto Clock I Setup Time 
(MI Cycle) 
0 
0 
0 
[8) 


15 
TdMl(IEO) 
MI I to IEO I Delay (Interrupt 
Immediately Preceding MI I) 
300 
190 
100 
[5,7] 


16 
TsIEI(IO) 
lEI to IORQ I Setup Time 
(INTACK Cycle) 
140 
140 
100 
(7) 


17 -TdIEI(IEOf)- lEI I to IEO I Delay 
190 
130 
120 
[5)- 
CL = 50 pF 


18 
TdIEI(IEOr) 
IEI t to IEO t Delay (after ED 
Decode) 
210 
160 
160 
[5] 


19 
TcIO(C) 
IORQ t to Clock I Setup Time 
(To Activate READY on Next 
Clock Cycle) 
220 
200 
170 
20 -TdC(RDYr)-· - 
Clock I to READY t Delay 
200 
190 
170 
[5]- 
CL = 50 pF 


21 
TdC(RDYf) 
Clock I to READY I Delay 
150 
140 
120 
[5] 


22 
TwSTB 
STROBE Pulse Width 
150 
150 
120 
[4] 


23 
TsSTB(C) 
STROBE t to Clock I Setup 
Time (To Activate READY on 
Next Clock Cycle) 
220 
220 
150 
[5] 


24 -TdIO(PD)-- IORQ t to PORT DATA Stable 


Delay (Mode 0) 
200 
180 
160 
[5] 


25 
TsPD(STB) 
PORT DATA to STROBE t 
Setup Time (Mode 1) 
260 
230 
190 


26 
TdSTB(PD) 
STROBE I to PORT DATA 
Stable (Mode 2) 
230 
210 
180 
[5] 


27 -TdSTB(PDr)- STROBE t to PORT DATA Float 
Delay (Mode 2) 
200 
180 
160 
CL = 50 pF 
28 
TdPD(INT) 
PORT DATA Match to INT I 


Delay (Mode 3) 
540 
490 
430 


29 
TdSTB(INT) 
STROBE I to INT I Delay 
490 
440 
350 


NOTES: 
[6J TsCS(RI) may be reduced. However, the lime subtracted 
[IJ TcC = .TwCh + TwCI + TrC + TIC. 
from TsCS(RI) will be added to TdR!(DO). 
[2J Increase TdRI(DO) by 10 ns for each 50 pF increase in load 
[7] 2.5 TcC > (N-2)TdIEI(IEOf) + TdMI(lEO) + TsIEI(IO) 
up to 200 pF max. 
.±... TTL Buffer Delay, if any. 
[3J Increase TdIO(DOI) by 10 ns for each 50 pF, increase in 
[8] MI must be active for a minimum of two clo~k cycles to 
loading up to 200 pF max. 
reset the PI~. 


[41 For Mode 2: TwSTB > TsPD(STB). 
[9] Z80B PIO numbers are preliminary and subject to change. 
[5] Increase these values by 2 ns for each 10 pF increase in 
loading up to 100 pF max. 
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Voltages on all inputs and outputs 
with respect to GND .......... -0.3 V to + 7.0 V 
Operating Ambient 
Temperature ................. As SpeCified in 
Ordering Information 
Storage Temperature ........ -65°C to +150°C 


The characteristics below apply for the 
folloWing test conditions, unless otherwise 
noted. All voltages are referenced to GND 
(0 V). Positive current flows into the refer- 
enced pin. Available operating temperature 
ranges are: 
m S* = O°C to + 70°C, 


+4.75 V:5 Vee:5 +5.25 V 


El E* = - 40°C to + 85°C, 


+ 4.75 V :5 Vee:5 + 5.25 V 
II M* = - 55°C to + 125°C, 


+ 4.5 V :5 Vee:5 + 5.5 V 
·See Ordering Information section for package 
temperature range and product number. 


Symbol 
Parameter 


VILe 
Clock Input Low Voltage 


VIHe 
Clock Input High Voltage 


VIL 
Input Low Voltage 


VIH 
Input High Voltage 


VOL 
Output Low Voltage 


VOH 
Output High Voltage 


ILl 
Input Leakage Current 


ILO 
3-State Output Leakage Current in Float 


lee 
Power Supply Current 


IOHD 
Darlington Drive Current 


Over speCified temperature and voltage range. 


Symbol 
Parameter 


C 
Clock Capacitance 
CIN 
Input Capacitance 


COUT 
Output Capacitance 


Over specified te\Tlperalure range; f'= lMHz 


Stresses greater than those listed under Absolute Maxi- 
mum Ratings may cause permanent damage to the device. 
This is a stress rating only; operation of the device at any 
condition above those indicated in the operational sections 
of these speCifications is not implied. Exposure to absolute 
maximum rating conditions for extended periods may affect 
device reliability. 


All ac parameters assume a load capacitance 
of 100 pF max. 


+5V 


2.1K 


Min 
Max 
Unit 
Test Condition 


-0.3 
+0.45 
V 
Vee-0.6 Vee+ 0.3 
V 


-0.3 
+0.8 
V 


+2.0 
Vee 
V 


+0.4 
V 
IOL = 2.0 rnA 
+2.4 
V 
IOH = -250 p.A 


± 10.0 
p.A 
VIN = 0 to Vee 


± 10.0 
p.A 
VOUT =0.4 V to Vee 


100.0 
rnA 
VoH =1.5 V 
-1.5 
rnA 
REXT = 390 n 


Min 
Max 
Unit 
Test Condition 


10 
pF 
Unmeasured 


5 
pF 
pins returned 


10 
pF 
to ground 


Ordering 
Product 
Package/ 
Product 
Package/ 


Information 
Number 
Temp 
Speed 
Description 
Number 
Temp 
Speed 
Description 


28420 
CE 
2.5 MHz 
280 PIO (40-pin) 
28420A 
CMB 
4.0 MHz 
280A PIO (40-pin) 


28420 
CM 
2.5 MHz 
Same as above 
28420A 
CS 
4.0 MHz 
Same as above 


28420 
CMB 
2.5 MHz 
Same as above 
28420A 
DE 
4.0 MHz 
Same as above 


28420 
CS 
2.5 MHz 
Same as above 
28420A 
DS 
4.0 MHz 
Same as above 


28420 
DE 
2.5 MHz 
Same as above 
28420A 
PE 
4.0 MHz 
Same as above 


28420 
DS 
2.5 MHz 
Same as above 
28420A 
PS 
4.0 MHz 
Sa,me as above 


28420 
PE 
4.0 MHz 
Same as above 
28420B 
CS 
6.0 MHz 
Same as above 


28420 
PS 
4.0 MHz 
Same as above 
28420B 
DS 
6.0 MHz 
Same as above 


28420A 
CE 
4.0 MHz 
280A PIO (40-pin) 
28420B 
PS 
6.0 MHz 
Same as above 


28420A 
CM 
4.0 MHz 
Same as above 


·NOTES: C = Ceramic, D = Cerdip, P = Plastic; E = -40°C to +85°C, M = -55°C to + 125°C, MB = 55°C to + 125°C with 


MIL-STD·883 Class B processing, S = O°C to + 70°C. 
I)i3 
eo 
0 
'" 


C::r.I 
0 


00-2006-02 
57 


Zilog 


Features 


General 
Description 
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IJ Four independently programmable 
counter/timer channels, each with a 
readable downcounter and a selectable 
16 or 256 prescaler. Downcounters are 
reloaded automatically at zero count. 


I'D Three channels have 2ero Count/Timeout 
outputs capable of driving Darlington 
transistors. 


The 2-80 CTC four-channel counter/timer 
can be programmed by system software for a 
broad range of counting and timing applica- 
tions. The four independently programmable 
channels of the 2-80 CTC satisfy common 
microcomputer system requirements for event 
counting, interrupt and interval timing, and 
general clock rate generation. 


System design is simplified because the CTC 
connects directly to both the 2-80 CPU and the 
2-80 SIO with no additional logic. In larger 
systems, address decoders and buffers may be 
required. 


Programming the CTC is straightforward: 


00 
CLKITRGo - 
0, 
ZCITOo 


02 
CPul~ 
03 
CLKITRG, 


DATA 


BUS 
- 
04 
ZCITO, 
CHANNEL 


Os 
SIGt.ALS 
- 


06 
CLKITRG2 
- 


07 
ZCfT02 


CE 
1- 


CSo 
CTC 


CONTROL 
- 
CS, 
FROM 
M1 
mer 
CPU 
_ 


lORa 
R1i 
Z80 CTC 
Z80A CTC 


DAISY { 
lEI 
CHAIN 
INTERRUPT 
lEO 


CONTROL 
iNf 


t t t 
CLK +5V GNO 


Figure 1. Pin Functions 


18430 


~80® CTC {C@Ulloofter/ 


~imer Circuil 


Product 
Specciiilcafti@ml 


September 1983 


C Selectable positive or negative trigger 
initiates timer operation. 


E'J Standard 2-80 Family daisy-chain interrupt 
structure prOVides fully vectored, prioritized 
interrupts without external logic. The CTC 
may also be used as an interrupt controller. 


I'J Interfaces directly to the 2-89 CPU or-for 
baud rate generation-to the 2-80 S10. 


each channel is programmed with two bytes; a 
third is necessary when interrupts are enabled. 
Once started, the eTC counts down, reloads 
its time constant automatically, and resumes 
counting. Software timing loops are completely 
eliminated. Interrupt processing is Simplified 
because only one vector need be speCified; the 
CTC internally generates a unique vector for 
each channel. 
The 2-80 CTC requires a single + 5 V power 
supply and the standard 2-80 single-phase 
system/clock. It is fabricated with n-channel 
silicon-gate depletion-load technology, and 
packaged in a 28-pin plastic or ceramic DIP. 


04 
03 


Os 
02 


06 
0, 


07 
00, 


GNO 
+5V 


RO 
CLKlTRGo 


ZC/TOo 
CLKfTRG, 


ZCITO, 
CLKlTRG2 


ZCIT02 
CLKITRG3 


lORa 
CS, 


lEO 
CSo 
iNT 
RESET 


lEI 
CE 
Mi 
CLK 


Figuro 2. Pin Assignmonts 
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Functional 
Description 


Architecture 
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The Z-80 CTC has four independent counter/ 
timer channels. Each channel is individually 
programmed with two words: a control word 
and a time-constant word. The control word 
selects the operating mode (counter or timer), 
enables or disables the channel interrupt, and 
selects certain other operating parameters. If 
the timing mode is selected, the control word 
also sets a pres caler , which divides the system 
clock by either 16 or 256. The time-constant 
word is a value from 1 to 256. 
During operation, the individual counter 
channel counts down from the preset time con- 
stant value. In counter mode operation the 
counter decrements on each of the CLK/TRG 
input pulses until zero count is reached. Each 
decrement is synchronized by the system 
clock. For counts greater than 256, more than 
one counter ca~ be cascaded. At zero count, 
the down-counter is automatically reset with 
the time constant value. 
The timer mode determines time intervals as 
small as 4 /LS (Z-80A) or 6.4 /LS (Z-80) without 
additional logic or software timing loops. Time 
intervals are generated by diViding the system 
clock with a prescaler that decrements 


The CTC has four major elements, as shown 
in Figure 3. 


• CPU bus I/O 
• Channel control logiC 
• Interrupt logic 
• Counter/timer circuits 
CPU Bus 110. The CPU bus I/O circuit 
decodes the address inputs, and interfaces the 
CPU data and control signals.to the CTC for 
distribution on the internal bus. 


FROM 
zeo CPU { 


DATA 


CONTROL 


CPU 
BUS 
110 


a preset down-counter. 
Thus, the time interval is an integral mul- 
tiple of the clock period, the prescaler value 
'(16 or 256) and the time constant that is preset 
in the down-counter. A timer is triggered auto- 
matically when its time constant value is 'pro- 
grammed, or by an external CLK/TRG input. 
Three channels have two outputs that occur 
at zero count. The first output is a zero- 
count/timeout pulse at the ZC/TO output. The 
fourth channel (Channel 3) does not have a 
ZC/TO output; interrupt request is the only 
output available from Channel 3. 
The second output is'Interrupt Request 
(lNT), which occurs if the channel has its 
interrupt enabled during programming. When 
the Z-80 CPU acknowledges Interrupt Request, 
the Z-80 CTC places an interrupt vector on the 
data bus. 
The four channels of the Z-80 CTC are fully 
prioritized and fit into four contiguous slots in 
a standard Z-80 daisy-chain interrupt struc- 
ture. Channel 0 is the highest priority and 
Channel 3 the lowest. Interrupts can be 
indiVidually enabled (or disabled) for each of 
the four channels. 


Internal Control Logic. The CTC internal 
control logic controls overa'll chip operating 
functions such as the chip enable, reset, and 
read/write logic. 
Interrupt Logic. The interrupt control logic 
ensures that the CTC interrupts interface prop- 
erly with the Z-80 CPU interrupt system. The 
logic controls the interrupt priority of the CTC 
as a function of the lEI Signal. If IEI is High, 
the CTC has priority. During interrupt 


ZCITO 


CLKlTRG 


Figure 3. Functional Block Diagram 
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Architecture 
(Continued) 
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processing, the interrupt logic holds lEO Low, 
which i'Ilhibits the interrupt operation on lower 
priority devices. If the lEI input goes Low, 
priority is relinquished and the interrupt logic 
drives lEO Low. 
If a channel is programmed to request an 
interrupt, the interrupt logic drives lEO Low at 
the zero count, and generates an INT signal to 
the Z-80 CPU. When the Z-80 CPU responds 
with interrupt acknowledge (M1 and IORQ), 
then the interrupt logic arbitrates the CTC 
internal priorities, and the interrupt control 
logic places a unique interrupt vector on the 
data bus. 
If an interrupt is pending, the interrupt logic 
holds lEO Low. When the Z-80 CPU issues a 
Return From Interrupt (RET!) instruction, each 
peripheral device decodes the first byte 
(ED16)' If the device has a pending interrupt, 
it raises lEO (High) for one M1 cycle. This 
ensures that all lower priority devices can 
decode the entire RET! instruction and reset 
properly. 


INTERNAL BUS 


ZCITO 


CLKlTRG -----I~I 


CLOCK ~I 
PRESCALER ~ 


Figure 4. Counter/Timer Block Diagram 


Counter/Timer Circuits. The CTC has four 
independent counter/timer circuits, each con- 
taining the logic shown in Figure 4. 


Channel Control Logic. The channel control 
logic receives the 8-bit channel control word 
when the counter/timer channel is pro- 
grammed. The channel control logic decodes 


the control word and sets the following 
operating conditions: 
c Interrupt enable (or disable) 


&a Operating mode (timer or counter) 
!I Timer mode prescaler factor (16 or 256) 
III Active slope for CLK/TRG input 


EI Timer mode trigger (automatic or CLKITRG 


input) 


r:J Time constant data word to follow 
[] Software reset 


Time Constant Register. When the counter/ 
timer channel is programmed, the time con- 
stant register receives and stores an 8-bit time 
constant value, which can be anywhere from 1 
to 256 (0 = 256). This constant is automatic- 
ally loaded into the down-counter when the 
counter/timer channel is initialized, and subse- 
, quently after each zero count. 


Prescaler. The prescaler, which is used only 
in timer mode, divides the system clock fre- 
quency by a factor of either 16 or 256. The 
prescaler output clocks the down-counter dur- 
ing timer operation. The effect of the prescaler 
on the down-counter is a multiplication of the 
system clock.period by 16 or 256. The pre- 
scaler factor is programmed by bit 5 of the 
channel control word. 


Down-Counter. Prior to each count cycle, the 
down-counter is loaded with the time constant 
register contents. The counter is then 
decremented one of two ways, depending on 
operating mode: 


I!I By the prescaler output (timer mode) 
D By the trigger pulses into the CLK/TRG 
input (counter mode) 


Without disturbing the down-count, the Z-80 
CPU can read the count remaining at any time 
by performing an I/O read operation at the 
port address assigned to the CTC channel. 
When the down-counter reaches the zero 
count, the ZC/TO output generates a p')sitive- 
going pulse. When the interrupt is enabled, 
zero count also triggers an interrupt request 
signal (INT) from the interrupt logic. 
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Programming 
Each Z-80 CTC channel must be pro- 
Do-D7 go to the hi<]h-impedarice state. All 
channels must be completely reprogrammed 
after a hardware re~et. 
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grammed prior to operation. Programming 
consists of writing two words to the I/O port 
that corresponds to the desired channel. The 
first word is a control word that selects the 
operating mode and other parameters; the 
second word is a time constant, which is a 
binary data word with a value from 1 to 256. A 
time constant word must be preceded by a 
channel control word. 
After initialization, channels may be 
reprogrammed at any time. If updated control 
and time constant words are written to a chan- 
. nel during the count operation, the count con- 
tinues to zero before the new time'constant is 
loaded into the counter. 
If the interrupt on any Z-80 CTC chgnnel is 
enabled, the programming procedure should 
also include an interrupt vector. Only one vec- 
tor is required for all four channels, because 
the interrupt logic automatically modifies the 
vector for the channel requesting service. 
A control word is identified by a 1 in bit O. 


A 1 in bit 2 indicates a time constant word is to 
follow. Interrupt vectors are always addressed 
to Channel 0, and identified by a 0 in bit O. 
Addressing. During programming, channels 
are addressed with the channel select pins CSl 
and CS2. A 2-bit binary code selects the 
appropriate channel as shown in the following 
table. 
Channel 
CSI 
CSo 


0 
0 
0 


1 
0 
1 
2 
1 
0 


3 
1 
1 


Reset. The CTC has both hardware and soft- 
ware resets. The hardware reset terminates all 
down-counts and disables all CTC interrupts 
by resetting the interrupt bits in the control 
registers. In addition, the ZC/TO and Interrupt 
outputs go inactive, lEO reflects IEI, and 


The software reset is controlled by bit 1 in 
the channel control word. When a channel 
receives a software reset, it stops counting. 
When a software reset is used, the other bits in 
the control word also change the contents of 
the channel control register. After a software 
reset a new time constant word must be written 
to the same channel. 
If the channel control word has both bits Dl 
and D2 set to I, the addressed channel stops 
operatirig, pending a new time constant word. 
The channel is ready to resume after the new 
constant is programmed. In timer mode, if 
D3 = 0, operation is triggered automatically 
when the time constant word' is loaded. 
Channel Control Word Programming. The' 
channel control word is shown in Figure 5. It 
sets the modes and parameters described 
below. 


Interrupt Enable. D7 enables the interrupt, so 
that an interrupt output (INT) is generated at 
zero count. Interrupts may be programmed in 
either mode and may be enabled or disabled 
at any time. 


Operating Mode. D6 selects either tiI11:er or 
counter mode. 
Prescaler Factor. (Timer Mode Only). D5 
selects factor-either 16 or 256. 
Trigger Slope. D4 selects the active edge or 
slope of the CLK/TRG input pulses. Note that 
reprogramming the CLK/TRG slope during 
operation is equivalent to issuing an active 
edge. If the trigger slope is changed by a con- 
trol word update while a channel is pending 
operation in timer mode, the result is the same 
as a CLK/TRG pulse and the timer starts. 
Similarly, if the channel is in counter mode, 
the counter decrements. 


I 0, I oslo, I 0.1 OJ I 0, I 0, 1'00 I 


. 
INTERRUPT jJ 
1 ENABLES INTERRUPT 
o DISABLES INTERRUPT 


MODE 
o SELECTS TIMER MODE 


1 SELECTS COUNTER MODE 


PRESCAlER VALUE' 


1 = VALUE OF 256 
o = VALUE OF 16 


ClK/TRG EDGE SELECTION __ 
----I 


o SELECTS FALLING EDGE 
1 SELECTS RISING EDGE t 


L CONTROL OR VECTOR 


o = VECTOR 
1 = CONTROL WORD 


RESET 


. 
0 = CONTINUED OPERATION 
1 = SOFTWARE RESET 


TIME CONSTANT 
o = NO TIME CONSTANT FOLLOWS 
1 = TIME CONSTANT FOLLOWS 


L--__ TIMER TRIGGER' 


o = AUTOMATIC TRIGGER WHEN 


TIME CONSTANT IS LOADED 
1 = CLK/TRG PULSE STARTS TIMER 


'TIMER MODE ONLY 


Figure S. Channel Control Word 
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Programming 
(Continued) 


2041·0160.0161 


Trigger Mode (Timer Mode Only). D3 selects 
the trigger mode for timer operation. When D3 
is reset to 0, the timer is triggered automatic- 
ally. The time constant word is programmed 
during an 1/0 write operation, which takes one 
machine cycle. At the end of the write opera- 
tion there is a setup delay of one clock period. 
The timer starts automatically (decrements) on 
the rising edge of the second clock pulse (T 2) 
of the machine cycle following the write opera- 
tion. Once started, the timer runs contin- 
uously. At zero count the timer reloads 
automatically and continues counting without 
interruption or delay, until stopped by a reset. 
When D3 is set to I, the timer is triggered 
externally through the CLK/TRG input. The 
time constant word is programmed during an 
1/0 write operation, which takes one machine 
cycle. The timer is ready for operation on the 
rising edge of the second clock pulse (T 2) of 
the follOWing machine cycle. Note that the first 
timer decrement follows the active edge of the 
CLK/TRG pulse by a delay time of one clock 
cycle if a minimum setup time to the rising 
edge of clock .is met. If this minimum is not 
met, the delay is extended by another clock 
period. Consequently, for immediate trigger- 
ing, the CLK/TRG input must precede T2 by 
one clock cycle plus its minimum setup time. 1£ 
the minimum time is not met, the timer. will 
start on the third clock cycle (T 3). 


Once started the timer operates contin- 
uously, without interruption or delay, until 
stopped by a reset. 


Time Constant to Follow. A 1 in D2 indicates 
that the next word addressed to the selected 
channel is a time constant data word for the 
time constant register. The time constant word 
may be written at any time. 
A 0 in D2 indicates no time constant word is 
to follow. This is ordinarily used when the 
channel is already in operation and the new 
channel control word is an update. A channel 
will not operate without a time constant value. 
The only way to write a time constant value is 
to write a control word with D2 set. 


:~:~ II ~~~~~ 
TC5~ 
LTC2 


TC. 
TC3 


Figure 6. Time Constant Word 


Software Reset. Setting D1 to 1 causes a soft- 
ware reset, which is described in the Reset 
section. 


Control Word. Setting Do to 1 identifies the 
word as a control word. 


Time Constant Programming. Before a chan- 
nel can start counting it must receive a time 
constant word from the CPU. During program- 
ming or reprogramming, a channel control 
word in which bit 2 is set must precede the 
time constant word to indicate that the next 
word is a time constant. The time constant 
word can be any value from 1 to 256 (Figure 
6). Note that 0016 is interpreted as 256. 
In timer mode, the time interval is controlled 
by three factors: 
m The system clock period (cp) 


Ell The prescaler factor (P), which multiplies 
the interval by either 16 or 256 


EJ The time constant (T), which is programmed 
into the time constant register 


Consequently, the time interval is the pro- 
duct of cp X P X T. The minimum timer resolu- 
tion is 16 X cp (4 p.s with a 4 MHz clock). The 
maximum timer interval is 256 x cp x 256 (16.4 ms 
with a 4 MHz clock) . For longer intervals 
timers may be cascaded. 


Interrupt Vector Programming. 1£ the 2-80 
CTC has one or more interrupts enabled, it 
can supply interrupt vectors to the 2-80 CPU. 
To do so, the 2-80 CTC must be pre-pro- 
grammed with the most-significant five bits of 
the interrupt vector. Programming consists of 
writing a vector word to the 1/0 port cor- 
responding to the 2-80 CTC Channel O. Note 
that Do of the vector word is always zero, to 
distinguish the vector from a channel control 
word. D1 and D2 are not used in programming 
the vector word. These bits are supplied by 
the interrupt logic to identify the channel 
requesting interrupt service with a unique 
interrupt vector (Figure 7). Channel 0 has the 
highest priority. 


V7-V3 =:=J 


SUPPLIED 


BY USER 
L 
L 0 = INTERRUPT VECTOR WORD 


1 = CONTROL WORD 


CHANNEL IDENTIFIER 
(AUTOMATICALLY INSERTED 
BY CTC) 
o 0 = CHANNEL 0 
o 1 = CHANNEL 1 
1 
0 = CHANNEL 2 
1 
1 = CHANNEL 3 


Figure 7. Interrupt Vector Word 
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Pin 
Description 
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CEo Chip Enable (input, active Low). When 
enabled the CTC accepts control words, inter- 
rupt vectors, or time constant data words from 
the data bus during an I/O write cycle; or: 
transmits the contents of the down-counter to 
the CPU during an 1/0 read cycle. In most 
applications this signal is decoded from the 
eight least significant bits of the address bus 
for any of the four 1/0 port addresses that are 
mapped to the four counter-timer channels. 


CLK. System Clock (input). Standard single- 
phase 2-80 system clock. 


CLK/TRGo-CLK/TRG3. External Clock/Timer 
Trigger (input, user-selectable active High or 
Low). Four pins corresponding to the four 2-80 
eTC channels. In counter mode, every active 
edge on this pin decrements the down-counter. 
In timer mode, an active edge starts the timer. 


CSO-CSI. Channel Select (inputs active High). 
Two-bit binary address code selects one of the 
four CTC channels for an 1/0 write or read 
(usually connected to Ao and AI). 
00-07. System Data Bus (bidirectional, 
3-state). Transfers all data and commands 
between the 2-80 CPU and the 2-80 CTC. 


SYSTEM 
BUSES 


lJL---l\ 


CPU _ r 
INT..l 


ry 
l' 


+5V T 


lEI 
ZC/TO, 


CTC 


lEO 


lEI 


RxCA 
iNr 


TxCA 
lEO 


RxCB 
hlB 


510 


-< 


- 
- 


vA 
\ 
['r--r' 


PIO 


iNr 


lEI 


lEO 
iNr 


lEI 


ROY 


DMA 


Figure S. A Typical Z-SO Environment 


lEI. Interrupt Enable In (input, active High). 
A High indicates that no other interrupting 
devices of higher priority in the daisy chain 
are being serviced by the 2-80 CPU. 
lEO. Interrupt Enable Out (output, active 
High). High only if IEI is High and the 2-80 
CPU is not servicing an interrupt from any 
2-80 CTC channel. IEO blocks lower priority 
devices from interrupting while a higher 
priority interrupting device is being serviced. 
INT. Interrupt Request (output, open drain, 
active Low). Low when any 2-80 CTC channel 
that has been programmed to enable interrupts 
has a zero-count condition in its down-counter. 


10RQ. Input/Output Request (input from CPU, 
active Low). Used with CE and RD to transfer 
data and channel control words between the 
2-80· CPU and the 2-80 CTC. During a write 
cycle, IORQ and CE are active and RD 
inactive. The 2-80 CTC does not receive a 
speCific write Signal; rather, it internally 
generates its own from the inverse of an active 
RD signal. In a read cycle, IORQ, CE and RD 
are active; the contents of the down-counter 
are read by the 2-80 CPU. If IORQ and Ml are 
both true, the CPU is acknowledging an inter- 
rupt request, and the highest priority inter- 
rupting channel places its interrupt vector on 
the 2-80 data bus. 
Ml. Machine Cycle One (input from CPU, 
active Low). When Ml and IORQ are active, 
the 2-80 CPU is acknowledging an interrupt. 
The 2-80 CTC then places an interrupt vector 
on the data bus if it has highest priority, and if 
a channel has requested an interrupt (INT). 
RD. Read Cycle Status (input, active Low). 
Used in conjunction with IORQ and CE to 
transfer data and channel control words 
between the 2-80 CPU and the 2-80 CTC. 
RESET. Reset (input active Lov/). Terminates 
all down-counts and disables all interrupts by 
resetting the interrupt bits in all control 
registers; the 2C/TO and the Interrupt outpi..tts 
go inactive; IEO reflects IEI; Do-D7 go to the 
high-impedance state. 


ZC/TOo-ZC/T02. Zero Count/Timeout (output, 
active High). Three 2C/TO pins corresponding 
to 2-80 CTC" channels 2 through 0 (Channel 3 
has no 2C/TO pin). In both counter and timer 
modes the output is an active High pulse when 
the down-counter decrements to zero. 


2041-0156 


Timing 
Read Cycle Timing. Figure 9 shows read 
cycle timing. This cycle reads the contents of a 
down-counter without disturbing the count. 
During clock cycle T2, the Z-80 CPU initiates a 
read cycle by driving the following inputs 
Low: RD, IORQ, and CEo A 2-bit binary code 
at inputs CS) and CSo selects the channel to 
be read. Ml must be High to distinguish this 
cycle from an interrupt acknowledge. No addi- 
tional wait states are allowed. 


CLK 


CSo. CS1. CE 
CHANNEL ADDRESS 
X 
__ 
-J 
X 
\ 
I 


RO 
\ 
r- 
_ --r-------------- 
",1 
I 
_.I 


OATA------'c ~ 


Figure 9. Read Cycle Timing 


Write Cycle Timing. Figure 10 shows write 
cycle timing for loading control, time constant 
or vector words. 
The CTC does not have a write signal input, 
so it generates one internally when the read 
(RD) input is High during T). During T2 
IORQ and CE inputs are Low. Ml must be 
High to distinguish a write cycle from an inter- 
rupt acknowledge. A 2-bit binary code at 
. 
inputs CS) and CSo selects the channel to be 
addressed, and the word being written is 
placed on the Z-80 data bus. The data word is 


CSo. CS1. CE -=--x 
CHANNEL ADDRESS r= 


IORQ 
\ 
I 


--7--------------------- 
no 
I 
_J 


- --..,.------------------ 
M1 
I 
--' 


OATA _______ -JX~ __ I_N_~X~ _______ __ 


Figuro 10. Write Cycle Timing 
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latched into the appropriate register with the 
rising edge of clock cycle T3. 


CLltlTRG 


INTERNAL 
START TIMING 
TlfAE'R 
---------' 


Figure 11. Timer Modo Timing 


Timer Operation. In the timer mode, a 
CLKITRG pulse input starts the timer (Figure 
11) on the second succe~ding rising edge of 
CLK. The trigger pulse is asynchronous, and it 
must have a minimum width. A minimum lead 
time (210 ns) is required between the active 
edge of the CLK/TRG and the next. rising edge 
of CLK to enable the prescaler on the follow- 
ing clock edge. If the CLK/TRG edge occurs 
closer than this, the initiation of the timer 
function is delayed one clock cycle. This cor- 
responds to the startup timing discussed in the 
programming section. The timer can also be 
started automatically if SO programmed by the 
channel control word. 


CLKITRG 


mTERUAL 
COUNTER ----",/ 


ZC/TO ____ 
--.I 


Figure 12. Counter Modo Timing 


Counter Operation. In the counter mode, the 
CLK/TRG pulse input decrements the down- 
counter. The trigger is asynchronous, but the 
count is synchronized with CLK. For the 
decrement to occur on the next rising ed<;16 of 
CLK, the trigger edge must precede CLK by a 
minimum lead time as shown in Figure 12. If 
the lead time is less than specified, the count 
is delayed by one clock cycle. The trigger 
pulse must have a minimum width, and the 
trigger period must be at least twice the clock 
period. 
The ZC/TO output occurs immediately after 
zero count, and follows the rising CLK edge. 
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Interrupt 
Operation 
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The Z-80 CTC follows the Z-80 system inter- 


rupt protocol for nested priority interrupts and 
return fron: interrupt, wherein the interrupt 
priority of a peripheral is determined by its 
location in a daisy chain. Two lines-lEI and 
lEO-in the CTC connect it to the system daisy 
chain. The device closest to the + 5 V supply 
has the highest priority (Figure 13). For addi- 
tional information on the Z-80 interrupt struc- 
ture, refer to the Z-BO CPU Product Specifica- 
tion and the Z-BO CPU Technical Manual. 


HIGHEST PRIORITY 
DEVICE 
LOWEST PRIORITY 
DEVICE 


Figure 13. Daisy-Chain Interrupt Priorities 


Within the Z-80 CTC, interrupt priority is 
predetermined by channel number: Channel 0 
has the highest priority, and Channel 3 the 
lowest. If a device or channel is being serviced 
with an interrupt routine, it cannot be inter- 
rupted by a device or channel with lower 
priority until service is complete. Higher' 
priority devices or channels may interrupt the 
servicing of lower priority devices or channels. 
A Z-80 CTC channel may be programmed to 
request an interrupt every time its down- 
counter reaches zero. Note that the CPU must 
be programmed for interrupt mode 2. Some 
time after the interrupt request, the CPU sends 
an interrupt acknowledge. The CTC interrupt 
control logic determines the highest priority 
channel that is requesting an interrupt. Then, 
if the CTC lEI input is High (indicating that it 
has priority within the system daisy chain) it 
places an 8-bit interrupt vector on the .system 
data bus. The high-order five bits of this vector 


CLK 


M1 
\ 
I 


IORO 
\ 
I 


IEI=======7 
\.==== 


DATA ----------~~>---- 


Figure 14. Interrupt Acknowledge Timing 


were written to the CTC during the program- 
ming process; the next two bits are provided 
by the CTC interrupt control logic as a binary 
code that identifies the highest priority chan- 
nel requesting an interrupt; the low-order bit 
is always zero. 
Interrupt Acknowledge Timing. Figure 14 
shows interrupt acknowledge timing. After an 
interrupt request, the Z-80 CPU sends an inter- 
rupt acknowledge (Ml and IORQ). All chan- 
nels are inhibited from changing their inter- 
rupt request status when Ml is active-about 
two clock cycles earlier than IORQ. RD is 
High to distinguish this cycle from an instruc- 
tion fetch. 
The CTC interrupt logic determines the 
highest priority channel requesting an inter- 
rupt. If the CTC interrupt enable input (lEI) is 
High, the highest priority interrupting channel 
within the CTC places its interrupt vector on 
the data bus when IORQ goes Low. Two wait 
states (TWA) are automatically inserted at this 
time to allow the daisy chain to stabilize. Addi- 
tional. wait states may be added. 
Return from Interrupt Timing. At the end of 
an interrupt service routine the RET! (Return 
From Interrupt) instruction initializes the daisy 
chain enable lines for proper control of nested 
priority interrupt handiing. The CTC decodes 
the 2-byte RET! code internally and determines 
whether it is intended for a channel being ser- 
viced. Figure 15 shows RETI timing. 
If several Z-80 peripherals are in the daisy 
chain, lEI settles active (High) on the chip 
currently being serviced when the opcode 
ED16 is decoded. If the folloWing opcode is 
4D16, the peripheral being serviced is released 
and its IEO becomes active. Additional wait 
states are allowed. 


Tl 
T2 
T3 


eLK 


M1\ 
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no 


Do-D7 
ED 


IEI- -- - 
- 
- 
-, 
______ J 
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------------------~ 


Figure 15. Roturn From Interrupt Timing 


2041-0166, 0167, 0168 


Absolute 
Maximum 
Ratings 


Test 
Conditions 


DC 
Character- 
istics 


8085-0239 


Voltages on all inputs and outputs 
with respect to GND .......... -0.3 V to + 7.0 V 
Operating Ambient 
As Specified in 
Temperature ........... Ordering Information 
Storage Temperature ........ -65°C to + 150°C 


The characteristics below apply for the 
folloWing test conditions, unless otherwise 
noted. All voltages are referenced to GND 
(0 V). Positive current flows into the refer- 
enced pin. Available operating temperature 
ranges are: 


C S* = O°C to + 70°C, 


+4.75 V!5 Vee!5 +5.25 V 
c E* = - 40°C to + 85°C, 
+4.75V!5Vee!5 +5.25V 


tJ M* = -55°C to + 125°C, 


+ 4.5 V !5 Vee !5 + 5.5 V 


Symbol 
Parameter 


VILe 
Clock Input Low Voltage 


VIHe 
Clock Input High Voltage 


VIL 
Input Low Voltage 


VlH 
Input High Voltage 


VOL 
Output Low Voltage 


VOH 
Output High Voltage 


Ice 
Power Supply Current 


III 
Input Leakage Current 


ILO 
3-State Output Leakage Current in Float 


IoHD 
Darlington Drive Current 


Symbol 
Parameter 
Max 


CLK 
Clock Capacitance 
20 


CIN 
Input Capacitance 
5 


COUT 
Output CapaCitance 
10 


TA = 25°C, f = 1 MHz 


Stresses greater than those listed under Absolute Maxi- 


mum Ratings may cause permanent damage to the device. 
This is a stress rating only; operation of the device at any 
condition above those indicated in the operational sections 
of these specifications is not implied. Exposure to absolute 
maximum rating conditions for extended periods may affect 
device reliability. 


·See Ordering Information section for PSlckage 
temperature range and product number. 


Min 
Max 


-0.3 
+0.45 


Vee-·6 Vee +.3 


-0.3 
+0.8 


+2.0 
Vee 
+0.4 


+2.4 


+20 


± 10 


±10 
-1.5 


Unit 


V 


V 


V 


V 


V 


V 


rnA 


p.A 


p.A 


rnA 


+5V 


2.1K 


Test Condition 


IoL = 2 rnA 


IoH = -250 p.A 


VIN = 0 to Vee' 


VOUT = 0.4 to Vee 


VOH = 1.5 V 
REXT = 390n 


Unit 
Condition 


pF 
U nrneasured pins 


pF 
returned to ground 


pF 
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~I 
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Z-80 CTC 
Z-80ACTC 
Z-80B CTC 
Min 
Max 
Min 
Max 
Min 
Max 
Number Symbol 
Parameter 
(ns) 
(ns) 
(ns) 
(ns) 
(ns) 
(ns)· 
Notes· 


1 
TcC 
Clock Cycle Time 
400 
[ I] 
250 
[ I] 
165 
[ I] 


2 
TwCH 
Clock Width (High) 
170 
2000 
105 
2000 
65 
2000 


3 
TwCl 
Clock Width (Low) 
170 
2000 
105 
2000 
65 
2000 


4 
TfC 
Clock Fall Time 
30 
30 
20 


5- TrC 
Clock Rise Time 
30 
30 
20 


6 
Th 
All Hold Times 
0 
0 
0 


7 
TsCS(C) 
CS to Clock , Setup Time 
250 
160 
100 


8 
TsCE(C) 
CE to Clock' Setup Time 
200 
150 
100 


9 
TsIO(C) 
IORQ 1 to Clock , Setup Time 
250 
115 
70 
10 - 
TsRD(C) -- RD 1 to Clock' Setup Time -- 240 
115 
70 


11 
TdC(DO) 
Clock , to Data Out Delay 
240 
200 
130 
[2] 


12 
TdC(DOz) 
Clock 1 to Data Out Float Delay 
230 
110 
90 


13 
TsDI(C) 
Data In to Clock t Setup Time 
60 
50 
40 
N 
CO 


14 
TsMl(C) 
Ml to Clock' Setup Time 
210 
90 
70 
0 


15 - 
TdMl(1EO)- Ml I to lEO I Delay (Interrupt 
tI 
immediately preceding Ml) 
300 
190 
130 
[3] 
" 
16 
TdIO(DOI) 
IORQ I to Data Out Delay 
340 
160 
110 
[2] 


(lN~ A Cycle) 


17 
TdlEl(lEOf) 
lEI I to lEO I Delay 
190 
130 
100 
[3] 


18 
TdIEI(lEOr) 
lEI , to lEO t Delay 
(After ED Decode) 
220 
160 
110 
[3] 


19 
TdC(lNT) 
Clock t to INT I Delay 
(TcC+200) 
(TcC+ 140) 
TcC+ 120 
[4] 


20 - 
TdCLK(INT) - 
CLK/TRG , to INT 1 
tsCTR(C) satisfied 
(19) + (26) 
(19) + (26) 
(19) + (26) 
[5] 


tsCTR(C) not satisfied 
(1) + (19) + (26) 
(1) + (19) + (26) (1) + (19) + (26) 
[5] 


21 
TcCTR 
CLK/TRG Cycle Time 
(2TcC) 
(2TcC) 
2TcC 
[5] 


22 
TrCTR 
CLK/TRG Rise Time 
50 
50 
40 


23 
TfCTR 
CLK/TRG Fall Time 
50 
50 
40 


24 
TwCTRI 
CLK/TRG Width (Low) 
200 
200 
120 


25 - 
TwCTRh -- CLK/TRG Width (High) 
200 
200 
120 


26 
TsCTR(Cs) 
CLK/TRG t to Clock t Setup 
Time for Immediate Count 
300 
210 
150 
[5] 


27 
TsCTR(Ct) 
CLK/TRG , to Clock t Setup 


Time for enabling of Prescaler 
on following clock t 
210 
210 
150 
[4] 


28 
TdC(ZC/TOr) 
Clock t to ZC/TO t Delay 
260 
190 
140 


29 
TdC(ZC/TOf) 
Clock I to ZC/TO I Delay 
190 
190 
140 


[A] 2.5 TcC > (n-2) TdIEI(IEOf) + TdMl(IEO) + TsIEI(lO) 
[3J Increase delay by 2 ns for each 10 pF increase in loading, 
+ TTL buffer delay, if any. 
100 pF maximum. 
[B] RESET must be active for a minimum of 3 clock cycles. 
[4] Timer mode. 


NOTES: 
[5J Counter mode. 


[1] TcC = TwCh + TwCl + TrC + TfC. 
[6J RESET must be active for a minimum of 3 clock cycles. 


[2J Increase delay by 10 ns for each 50 pF increase in loading, 
• All timings are preliminary and subject to change. 


200 pF maximum for data lines, and 100 pF for control lines. 
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Product 
Package/ 
Product 
Package/ 
Number 
Temp 
Speed 
Description 
Number 
Temp 
Speed 
Description 


28430 
CE 
2.5 MHz 
280 CTC (28-pin) 
28430A 
CMB 
4.0 MHz 
280A CTC (28-pin) 


28430 
CM 
2.5.MHz 
Same as above 
28530A 
CS 
4.0 MHz 
Same as above 


28430 
CMB 
2.5 MHz 
Same as above 
28430A 
DE 
4.0 MHz 
Same as above 


28430 
CS 
2.5 MHz 
Same as above 
28430A 
DS 
4.0 MHz 
Same as above 


28430 
DE 
2.5 MHz 
Same as above 
28430A 
PE 
4.0 MHz 
Same as above 


28430 
DS 
2.5 MHz 
Same as above 
28430A 
PS 
4.0 MHz 
Same as above 


28430 
PE 
2.5 MHz 
Same as above 
28430B 
CS 
6.0 MHz 
Same as above 


28430 
PS 
2.5 MHz 
Same as above 
28430B 
DS 
6.0 MHz 
Same as' above 


28430A 
CE 
4.0 MHz 
280A CTC (28-pin) 
28430B 
PS 
6.0 MHz 
Same as above 


28430A 
CM 
4.0 MHz 
Same as above 


"NOTES: C = Ceramic, D = Cerdip, P = Plastic; E = -40°C to +85°C, M = -55°C to + 125°C, MB = -55°C to + 125°C with 


MIL·STD·883 Class B processing, S = O°C to + 70°C. 
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Features 


General 
Description 


2042·0111, 0120 


[J Two independent full-duplex channels, with 
separate control arid status lines for modems 
or other devices. 


[J Data rates of 0 to 500K bits/second in 
the xl clock mode with a 2.5 MHz clock 
(Z-BO SIO), or 0 to BOOK bits/second with a 
4.0 MHz clock (Z-BOA SIO). 


[J Asynchr.onous protocols: everything 
necessary for complete messages in 5, 6, 7 
or B bits/character. Includes variable stop 
bits and several clock-rate multipliers; 
break generation and detection; parity; 
overrun and framing error detection. 


The Z-BO SIO Serial Input/Output Control- 


ler is a' dual-channel data communication 
interface with extraordinary versatility and 
capability. Its basic functions as a serial-to- 
parallel, parallel-to-serial converter/controller 
can be programmed by a CPU for a broad 
range of serial communication applications. 
The device supports all common asyn- 


chronous and synchronous protocols, byte- or 


RxDA .-- 


TxOA 


BUS ~ 
°4 


Z8440 
Z80® SIO Serial 
l!lmptmft/(J)ulpul Controller 


Product 
Specification 


September 1983 


IJ Synchronous protocols: everything 
necessary for complete bit- or byte-oriented 
messages in 5, 6, 7 or B bits/character, 
including IBM Bisync, SDLC, HDLC, 
CCITT-X.25 and others. Automatic CRC 
generation/checking, sync character and 
zero insertion/deletion, abort genera- 
tion/detection and flag insertion. 


[] Receiver data registers quadruply buffered, 
transmitter registers doubly buffered. 


[J Highly sophisticated and flexible daisy- 


chain interrupt vectoring for interrupts 
without external logic. 


bit-oriented,' and performs all of the functions 
traditionally done by UARTs, USARTs and 
. synchronous communication controllers com- 
bined, plus additional functions traditionally 
performed by the CPU. Moreover, it does this 
on two fully-independent channels, with an 
exceptionally sophIsticated interrupt structure 
that allows very fast transfers. 
Full interfaCing is provided for CPU or DMA· 
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control. In addition to data communication, the 
circuit can handle virtually all types of serial 
I/O with fast (or slow) peripheral devices. 
While designed primarily as a member of the 
Z-80 family, its versatility makes it well suited 
to many other CPUs. 


Figures 1 through 6 illustrate the three pin 
configurations (bonding options) available in 
the S10. The constraints of a 40-pin package 
make it impossible to bring out the Receive 
Clock (RxC), Transmit Clock (TxC)' Data Ter- 
minal Ready (DTR) and Sync (SYNC) signals 
for both channels. Therefore, either Chan~el B 
lacks a signal or two signals are bonded 
together in the three bonding options offered: 


• Z-80 S10/2 lacks SYNCB 


• Z-80 SIO/1 lacks DTRB 


• Z-80 S1010 has all four signals, but TxCB 


and RxCB are bonded together 


The first bonding option above (SI0/2) is the 
preferred version for most applications. The 
pin descriptions are as follows: 


B/A. Channel A Or B Select (input, High 
selects Channel B). This input defines which 
channel is accessed during a data transfer 
between the CPU and the S10. Address bit Ao 
from the CPU is often used for the selection 
function. 
C/D. Control Or Data Select (input, High 
selects Control). This input defines the type of 
information transfer performed between the 
CPU and the S10. A High at this input during 
a CPU write to the S10 causes the information 
on the data bus to be interpreted as a com- 
mand for the channel selected by BilL A Low 
at c/B means that the information on the data 
bus is data. Address bit Al is often used for 
this function. 


hDA 


BUS 
~ 
04 


The Z-80 S10 is an n-channel silicon-gate 
depletion-load device packaged in a 40-pin 
plastic or ceramic DIP. It uses a single + 5 V 
power supply and the standard Z-80 family 
single-phase clock. 


CEo Chip Enable (input, active Low). A Low 
level at this input enables the 810 to accept 
command or data input from the CPU during a 
write cycle or to transmit data to the CPU 
during a read cycle. 


CLK. System Clock (input). The S10 uses the 
standard Z-80 System Clock to synchronize 
internal signals. This is a single-phase clock. 


CTSA, CTSB. Clear To Send (inputs, active 
Low). When programmed as Auto Enables, a 
Low on these inputs enables the respective 
transmitter. If not programmed as Auto 
Enables, these inputs may be programmed as 
general-purpose inputs. Both inputs are 
Schmitt-trigger buffered to accommodate slow- 
risetime signals. The S10 detects pulses on 
these inputs and interrupts the CPU on both 
logic level transitions. The Schmitt-trigger buf- 
fering does not guarantee a specified noise- 
level margin. 


00-07. System Data Bus (bidirectional, 
3-state). The system data bus transfers data 
and commands between the CPU and the Z-80 
S10. Do is the least significant bit. 


DCDA, DCDB. Data Carrier Detect (inputs, 
active Low). These pins function as receiver 
enables if the S10 is programmed for Auto 
Enables; otherwise they may be used as 
general-purpose input pins. Both pins are 
Schmitt-trigger buffered to accommodate slow- 
risetime signals. The S10 detects pulses on 
these pins and interrupts the CPU on both 
logic level transitions. Schmitt-trigger buffer- 
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ing does not guarantee a specific noise-level 
margin. 


DTRA, DTRB. Data Terminal Ready (outputs, 
active Low). These outputs follow the state pro- 
grammed into 2-80 SIO. They can also be pro- 
grammed as general-purpose outputs. 
In the 2-80 SIO/l bonding option, DTRB is 
omitted. 


lEI. Interrupt Enable In (input, active High). 
This signal is used with lEO to form a priority 
daisy chain when there is more than one 
interrupt-driven device. A High on this line 
indicates that no other device of higher pri- 
ority is being serviced by a CPU interrupt ser- 
vice routine. 


lEO. Interrupt Enable Out (output, active 
High). lEO is· High only if lEI is High and the 
CPU is not servicing an interrupt from this 
SIO. Thus, this signal blocks lower priority 
devices from interrupting while a higher 
priority device is being serviced by its CPU 
interrupt service routine. 


INT. Interrupt Request (output, open drain, 
active Low). When the SIO is requesting an 
interrupt, it pulls INT Low. 


10RQ. Input/OutPllt Request (input from CPU, 
active Low). 10RQ is used in conjunction with 
BIA, C/D, CE and RD to transfer commands 
and data between the CPU and the SIO. When 
CE, RD and 10RQ are all active, the channel 
selected by BIA transfers data to the CPU (a 
read operation). When CE and 10RQ are 
active but RD is inactive, the channel selected 
by BIA is written to by the CPU with either 
data or control information as speCified by 
C/f). If 10RQ and Ml are active simultane- 


hCA -- 
BUS ~ 
0 4 
SYNCA ~ 


ously, the CPU is acknowledging an interrupt 
and the SIO automatically places its interrupt 
vector on the CPU data bus if it is the highest 
priority device requesting an interrupt. 
MI. Machine Cycle (input from 2-80 CPU, 
active Low). When Ml is active and RD is also 
active, the 2-80 CPU is fetching an instruction 
from memory; when Ml is active while 10RQ is 
active, the SIO accepts Ml and 10RQ as an 
interrupt acknowledge if the SIO is the highest 
priority device that has interrupted the 2-80 
CPU. 


RxCA, RxCB. Receiver Clocks (inputs). 
Receive data is sampled on the rising edge of 
RxC. The Receive Clocks may be I, 16, 32 or 
64 times the data rate in asynchronous modes. 
These clocks may be driven by the 2-80 CTC 
Counter Timer Circuit for programmable baud 
rate generation. Both inputs are Schmitt- 
trigger buffered (no noise level margin is 
speCified) . 
In the 2-80 SIO/O bonding option, RxCB is 
bonded together with TxCB. 


RD. Read Cycle Status (input from CPU, 
active Low). If RD is active, a memory or 1/0 
read operation is in progress. RD is used with 
BIA, CE and 10RQ to transfer data from the 
SIO to the CPU. 


RxDA, RxDB. Receive Data (inputs, active 
High). Serial data at TTL levels. 


RESET. Reset (input, active Low). A Low 
RESET disables both receivers and transmit- 
ters, forces TxDA and TxDB marking, forces 
the modem controls High and disables all 
interrupts. The control registers must be 
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rewritten after the SIO is reset and before data 
is transmitted or received. 
RTSA. RTSB. Request To Send (outputs, 
active Low). When the RTS bit in Write 
Register 5 (Figure 14) is set, the RTS output 
goes Low. When the RTS bit is reset in the 
Asynchronous mode, the output goes High 
after the transmitter is empty. In Synchronous 
modes, the RTS pin strictly follows the state of 
the RTS bit. Both pins can be used as general- 
purpose outputs. 


SYNCA. SYNCB. Synchronization (inputs/out- 
puts, active Low). These pins can act either as 
inputs or outputs. In the asynchronous receive 
mode, they are inputs similar to CTS and 
DCD. In this mode, the transitions on these 
lines affect the state of the Sync/Hunt status 
bits in Read Register 0 (Figure 13)' but have 
no other function. In the External Sync mode, 
these lines also act as inputs. When external 
synchronization is achieved, SYNC must be 
driven Low on the second rising edge of RxC 
after that rising edge of RxC on which the last 
bit of the sync character was received. In 
other words, after the sync pattern is detected, 
the external logic must wait for two full 
Receive Clock cycles to activate the SYNC 
input. Once SYNC is forced Low, it should be 
kept Low until the CPU informs the external 
synchronization detect logic that synchroniza- 
tion has been lost or a new message is about to 
start. Character assembly begins on the rising 
edge of RxC that immediately precedes the 
falling edge of SYNC in the External Sync 
mode. 
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In the internal synchronization mode 
(Monosync and Bisync), these pins act as out- 
puts that are active during the part of the 
receive clock (RxC) cycle in which sync 
characters are recognized. The sync condition 
is not latched, so these outputs are active each 
time a sync pattern is recognized, regardless 
of character boundaries. 
In the 2-80 SIO/2 bonding option, SYNCB 


is omitted. 
TxCA. TxCB. Transmitter Clocks (inputs). In 
asynchronous modes, the Transmitter Clocks 
may be 1, 16, 32 or 64 times the data rate; 
however, the clock multiplier for the transmit- 
ter and the receiver must be the same. The 
Transmit Clock inputs are Schmitt-trigger buf- 
fered for relaxed rise- and fall-time require- 
ments (no noise level margin is specified). 
Transmitter Clocks may be'driven by the 2-80 
CTC Counter Timer Circuit for programmable 
baud rate generation. 
In the 2-80 S10/O bonding option, TxCB is 
bonded together with RxCB. 
TxDA. TxDB. Transmit Data (outputs, active 
High). Serial data at TTL levels. TxD changes 
from the falling edge of TxC. 
W/RDYA. W/RDYB. Waif/Ready A, Waif/ 
Ready B (outputs, open drain when pro- . 
grammed for Wait function, driven High and 
Low when programmed for Ready function). 
These dual-purpose outputs may be pro- 
grammed as Ready lines for a DMA controller 
or as Wait lines that synchronize the CPU to 
the S10 data rate. The reset state is open 
drain. 
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The functional capabilities of the 2-80 SIO 


can be described from two different points of 
view: as a data communications device, it 
transmits and receives serial data in a wide 
variety of data-communication protocols; as a 
2-80 family peripheral, it interacts with the 
2-80 CPU and other peripheral circuits, shar- 
ing the data, address and control buses, as 
well as being a part of the 2-80 interrupt struc- 
ture. As a peripheral to other microprocessors, 


MICROPROCESSOR { 


INTERFACE 


the SIO offers valuable features such as non- 
vectored interrupts, polling and simple hand- 
shake capability. 
Figure 8 illustrates the conventional devices 
that the SIO replaces. 
The first part of the following discussion 
covers SIO data-communication capabilities; 
the second part describes interactions between 
the CPU and the SIO. 
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Figure 8. Conventional Devices Replaced by the Z-80 SIO 


The SIO provides two independent full- 
duplex channels that can be programmed for. 
use in an:y common asynchronous or synchro- 
nous data-communication protocol. Figure 9 
illustrates some of these protocols. The follow- 
ing is a short description of them. A more 
detailed explanation of these modes can be 
found in the Z-80 510 Technical Manual. 


Asynchronous Modes. Transmission and 
reception can be done independently on each 
channel with five to eight bits per character, . 
plus optional even or odd parity. The transmit- 
ters can supply one, one-and-a-half or two stop 
bits per character and can provide a break 
output at any time. The receiver break- 
detection logic interrupts the CPU both at the 
start and end of a received break. Reception is 
protected from spikes by a transient spike- 
rejection mechanism that checks the signal 
one-half a bit time after a Low level is detected 
on the receive data input (RxDA or RxDB in 
Figure 5). If the Low does not persist-as in 
the case of a transient-the character assembly 
process is not started. 
Framing i.errors and overrun errors are 
detected and buffered together with the partial 
character on which they occurred. Vectored 


interrupts allow fast servicing of error condi- 
tions using dedicated routines. Furthermore, a 
built-in checking process avoids interpreting a 
framing error as a new start bit: a framing 
error results in the addition of one-half a bit 
time to the point at which the search for the 
next start bit is begun. 
The SIO does not require symmetric transmit 
and receive clock signals-a feature that 
allows it to be used with a 2-80 CTC or many 
other clock sources. The transmitter and 
receiver can handle data at a rate of I, 1116, 
1132 or 1164 of the clock rate supplied to the' 
receive and transmit clock inputs. 
In asynchronous modes, the SYNC pin may 
be programmed as an input that can be used 
for functions such as monitoring a ring 
indicator. 


Synchronous Modes. The SIO supports both 
byte-oriented and bit-oriented synchronous 
communication. 
Synchronous byte-oriented protocols can be 
handled in several modes that allow character 
synchronization with an 8-bit sync character 
(Monosync), any 16-bit sync pattern (Bisync), 
or with an external sync signal. Leading sync 
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characters can be removed without interrupt- 
ing the CPU. 


Five-, six- or seven-bit sync characters are 
detected with 8- or 16-bit patterns in the SIO 
by overlapping the larger pattern across multi- 
ple in-coming sync characters, as shown in 
Figure 10. 


CRC checking for synchronous byte- 


oriented modes is delayed by one character 
time so the CPU may disable CRC checking on 
specific characters. This permits implementa- 
tion of protocols such as IBM Bisync. 
Both CRC-16 (X16 + XI5 + X2 + 1) and 
CCITT (X16 + XI2 + X5 + 1) error checki~g 
polynomials are supported. In all non-SDLC 
modes, the CRC generator is initialized to O's; 
in SDLC modes, it is initialized to l's. The SIO 
can be used for interfacing to peripherals such 
as hard-sectored floppy disk, but it cannot 
generate or check CRC for IBM-compatible 
soft-sectored disks. The SIO also provides a 
feature that automatically transmits CRC data 
when no other data is available for transmis- 
sion. This allows very high -speed transmissions 
under DMA control with no need for CPU 
intervention at the end of a message. When 
there is no data or CRC to send in syn- 
chronous modes, the transmitter inserts 8- or. 
16-bit sync characters regardless of the pro- 
grammed character length. 
The SIO supports synchronous bit-oriented 
protocols such as SDLC and HDLC by per- 
forming automatic flag sending, zero insertion 
and CRC generation. A special command can 
be used to abort a frame in transmission. At 
. the end of a message the SIO automatically 
transmits the CRC and trailing flag when the 
transmit buffer becomes empty. If a transmit 
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STr 


T rr 
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underrun occurs in the middle of a message, 
an external/status interrupt warns the CPU of 
this status change so that an abort may be 
issued. One to eight bits per character can be 
sent, which allows reception of a message with 
no prior information about the character struc- 
ture in the information field of a frame. 
The receiver automatically synchronizes on 
the leading flag of a frame in SDLC or HDLC, 
and provides a synchronization signal on the 
SYNC pin; an interrupt can also be pro- 
grammed. The receiver can be programmed to 
search for frames addressed by a single byte to 
only a specified user-selected address or to a 
global broadcast address. In this mode, frames 
that do not match either the user-selected or 
broadcast address are ignored. The number of 
address bytes can be extended under software 
control. For transmitting data, an interrupt on 
the first received character or on every 
character can be selected. The receiver 
automatically deletes all zeroes inserted by the 
transmitter during character assembly. It also 
calculates and automatically checks the CRC 
to validate frame transmission. At the end of 
transmission, the status of a received frame is 
available in the status registers. 
The SIO can be conveniently used under 
DMA control to provide high-speed reception 
or transmission. In reception, for example, the 
SIO can interrupt the CPU when the first 
character of a message is received. The CPU 
then enables the DMA to transfer the message 
to memory. The SIO then issues an end-of- 
frame interrupt and the CPU can check the 
status of the received message. Thus, the CPU 
is freed for other service while the message is 
being received. 
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Figure 9. Some Z-80 SIO Protocols 


6 BITS 
~ 


. SYNq I SYNC 
DATA 


'-----..,------ 


8 


~-----v~------~ 


16 


DATA 


CRC, 


CRC2 


CRC2 


CRC2 


DATA 


Figure 10. Six-Bit Sync Character Recognition 


FLAG 


DATA 


2042-0lO8, OlO9 


II 0 Interface 
Capabilities 
The SIO offers the choice of polling, inter- 
rupt (vectored or non-vectored) and block- 
transfer modes to transfer data, status and con- 
trol information to and from the CPU. The 
block-transfer mode can also be implemented 
under DMA control. 
I 


Polling. Two status registers are updated at 
appropriate times for each function being per- 
formed (for example, CRC error-status valid at 
the end of a message). When the CPU is 
operated in a polling fashion, one of the SIO's 
two status registers is used to indicate whether 
the SIO has some data or needs some data. 
Depending on the contents of this register, the 
CPU will either write data, read data, or just 
go on. Two bits in the register indicate that a 
data transfer is needed. In addition, error and 
other conditions are indicated. The second 
status register (special receive conditions) does 
not have to be read in a polling sequence, 
until a character has been received. All inter- 
rupt modes are disabled when operating the 
device in a polled environment. 


Interrupts. The SIO has an elaborate interrupt 
scheme to provide fast interrupt service in 
real-time applications. A control register and a 
status register in Channel B contain the inter- 
rupt vector. When programmed to do so, the 
SIO can modify three bits of the interrupt vec- 
tor in the status register so that it points direct- 
ly to one of eight interrupt service routines in 
memory, thereby servicing conditions in both 
channels and eliminating most of the needs for 
a status-analysis routine. 
Transmit interrupts, receive interrupts and 
external/status interrupts are the main sources 
of interrupts. Each interrupt source is enabled 
under- program control, with Channel A hav- 
ing a higher priority than Channel B, and with 
receive, transmit and external/status interrupts 
prioritized in that order within each channel. 
When the transmit interrupt is enabled, the 


CPU is interrupted by the transmit buffer 
becoming empty. (This implies that the 
transmitter must have had a data character 
written into it so it can become empty.) The 
receiver can interrupt the CPU in one of two 
ways: 


• Interrupt on first received character 


• Interrupt on all received characters 


Interrupt-on-first-received-character is 
typically used with the block-transfer mode. 
Interrupt-on-all-received-characters has the 
option of modifying the interrupt vector in the 
event of a parity error. Both of these interrupt 
modes will also interrupt under special receive 
conditions on a character or message basis 
(end-of-frame interrupt in SDLC, for example). 
This means that the special-receive condition 
can cause an interrupt only if the interrupt-on- 
first-recei ved-character or in terru pt -on -all- 
received-characters mode is selected. In 
interrupt-on-first-received-character, an inter- 
rupt can occur from special-receive conditions 
(except parity error) after the first-received- 
character interrupt (example: receive-overrun 
interrupt) . 
The main function of the external/status 
interrupt is to monitor the Signal transitions of 
the Clear To Send (CTS), Data Carrier Detect 
(DCD) and Synchronization (SYNC) pins 
(Figures 1 through 6). In addition, an exter- 
nal/status interrupt is also caused by a CRC- 
sending condition or by the detection of a 
break sequence (asynchronous mode) or abort 
sequence (SDLC mode) in the data stream. 
The interrupt caused by the break/abort 
sequence allows the SIO to interrupt when the 
break/abort sequence is detected or ter- 
minated; This feature facilitates the proper ter- 
mination of the current message,- correct 
initialization of the next message, and the 
accurate timing of the break/abort condition in 
external logic. 
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In a 2-80 CPU environment (Figure 11), SIO 


interrupt vectoring is "automatic": the SIO 
passes its internally-modifiable 8-bit interrupt 
vector to the CPU, which adds an additional 8 
bits from its interrupt-vector (I) register to form 
the memory address of the interrupt-routine 
table. This table contains the address of the 
beginning of the interrupt routine itself. The 
process entails an indirect transfer of CPU 
control to the interrupt routine, so that the 
next instruction executed after an interrupt 
acknowledge by the CPU is the first instruction 
of the interrupt routine itself. 
CPU/DMA Block Transfer. The SIO's block- 
transfer mode accommodates both CPU block 
transfers and DMA controllers (Z-80 DMA or 
other designs). The block -transfer mode uses 
the Wait/Ready output signal, which is 
. 


selected with three bits in an internal control 
register. The Wait/Ready output signal can be 
programmed as a WAIT line in the CPU block- 
transfer mode or as a READY line in the DMA 
block-transfer mode. 
To a DMA controller, the SIO READY output 
indicates that the SIO is ready to transfer data 
to or from memory. To the CPU, the WAIT out- 
put indicates that the SIO is not ready to 
transfer data, thereby requesting the CPU to 
extend the I/O cycle. 


The internal structure of the device includes 
a Z-80 CPU interface, internal control and 
interrupt logic, and two full-duplex channels. 
Each channel contains its own set of control 
and status (write and read) registers, and con- 
trol and status logic that provides the interface 
to modems or other external devices. 
The registers for each channel are desig-· 


nated as follows: 


WRO-\"1R7 - 
Write Registers 0 through 7 
RRO-RR2 - 
Read Registers 0 through 2 


The register group includes five 8-bit control 
registers, two sync-character registers and two 
status registers. The interrupt vector is written 
into an additional 8-bit register (Write Register 
2) in Channel B that may be read through 
another 8-bit register (Read Register 2) in 
Channel B. The bit assignment and functional 
grouping of each register is configured to 
simplify and organize the programming pro- 
cess. Table 1 lists the functions assigned to 
each read or write register. 


CPU 


SYSTEM 
BUSES 


Vt----\ 
~ 
I 


INT- 


+5V 
T 


lEI 


ZCITO, 


CTC 


ZCIT02 
iNT 
lEO 


lEI 
RxCA 
iNT 


TxCA 
lEO 


RxCS 


TxCS 


WIROYA 


WIROYB 


SIO 
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--< 
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1\ 
.y--y 


DMA 


-INT 


ROY 


lEI 


lEO 
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lEI 


ROY 


DMA 


Figure II. Typical Z-80 Environment 


Read Register Functions 


RRO 
Transmit/Receive buffer status, interrupt 
status and external status 


RRI 
Special Receive Condition status 


RR2 
Modified interrupt vector '(Channel B only) 


Write Register Functions 


WRO 
Register pointArs, CRC initialize, initializa- 
tion commands for the various modes, etc. 


WRI 
Transmit/Receive interrupt and data transfer 
mode definition. 


WR2 
Interrupt vector (Channel B only) 


WR3 
Receive parameters,and control 


WR4 
Transmit/Receive miscellaneous parameters 
and modes 


WR5 
Transmit parameters and controls 


WR6 
Sync character or SDLC address field 


WR7 
Sync character or SDLC flag 


2032-0127 


Internal 
Structure 
(Continued) 


2042-0112 


The logic for both channels provides for- 
mats, synchronization and validation for data 
transferred to and from the channel interface. 
The modem control inputs, Clear To Send 
(CTS) and Data Carrier Detect (DCD), are 
monitored by the external control and status 
logic under program control. All external 
control-and-status-logic signals are general- 
purpose in nature and can be used for func- 
tions other than modem control. 


Data Path. The transmit and receive data path 
illustrated for Channel A in Figure 12 is iden- 
tical for both channels. The receiver has three 
8-bit buffer registers in a FIFO arrangement, 
in addition to the 8-bit receive shift register. 
This scheme creates additional time for the 


CPU to service an interrupt at the beginning of 
a block of high-speed data. Incoming data is 
routed through one of several paths (data or 
CRC) depending on the selected mode 
and-in asynchronous modes-the character 
length. 
The transmitter has an 8-bit transmit data 
buffer register that is loaded from the internal 
data bus, and a 20-bit transmit shift register 
that can be loaded from the sync-character 
buffers or from the transmit data register. 
Depending on the operational mode, outgoing 
data is routed through one of four main paths 
before it is transmitted from the Transmit Data 
output (TxD). 


CPU I/O 


"O~'" 


TOCHANNELB.----------------------------------~~----------------------------------- 


EXT~~~~~~IALT~51~~~~g: _______________ .""..-__________ ....,.,... __ 
IN_TE_R_N_AL_D_A_TA_B_U--,S 


TxDA 


Figure 12. Transmit and Receive Data Path (Channel A) 
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N 
00 
C 
(I) ... o 


Programming 
The system program first issues a series of 


80 


commands that initialize the basic mode of 
operation and then other commands that 
qualify conditions within the selected mode. 
For example, the asynchronous mode, 
character length, clock rate, number of stop 
bits, even or odd parity might be set first; then 
the interrupt mode; and finally, receiver or 
transmitter enable. 
Both channels contain registers that must be 
programmed via the system program prior to 
operation. The channel-select input (BfA) and 
the control/data input (c/iS) are the command- 
structure addressing controls, and are normal- 
ly controlled by the CPU address bus. Figures 
15 and 16 illustrate the timing relationships for 
programming the write registers and transfer- 
ring data and status. 


Read Registers. The S10 contains three read 
registers for Channel B and two read registers 
for Channel A (RRO-RR2 in Figure 13) that can 
be read to obtain the status information; RR2 
contains the internally-modifiable interrupt 
vector and is only in the Channel B register 
set. The status information includes error con- 
ditions, interrupt vector and standard 
communications-interface signals. 
To read the contents of a selected read 
register other than RRO, the system program 
must first write the pointer byte to WRO in 
exactly the same way as a write register opera- 
tion. Then, by executing a read instruction, 
the contents of the addressed read register can 
be read by the CPU. 


The status bits of RRO and RRI are carefully 
grouped to Simplify status monitoring. For 
example, when the interrupt vector indicates 
that a Special Receive Condition interrupt has 
occurred, all the appropriate error bits can be 
read from a single register (RRl). 


Write Registers. The S10 contains eight v/rite 
registers for Channel B and seven write 
registers for Channel A (WRO-WR7 in Figure 
14) that are programmed separately to con- 
figure the function'al personality of the chan- 
nels; WR2 contains the interrupt vector for 
both channels and is only in the Channel B 
register set. With the exception of WRO, pro- 
gramming the write registers requires two 
bytes. The first byte is to WRO and contains 
three bits (Do-D2) that point to the selected 
register; the second byte is the actual control 
word that is written into the register to con- 
figure the S10. 


WRO is a special case in that all of the basic 
commands can be written to it with a single 
byte. Reset (internal or external) initializes the 
pointer bits Do-D2 to point to WRO. This 
implies that a channel reset must not be com- 
bined with the pointing to any register. 


READ REGISTER 0 


III ~I 
I L- 
Rx 


CHARACTER AVAILABLE 
L.::= INT PENDING (CH, A ONLY) 


~~gUFFER EMPTY 
} 


SYNC/HUNT 
CTS 
• 


Tx UNDERRUN/EOM 
BREAK/ABORT 


READ REGISTER It 


·Used With "ExternaliStatus 
InterrUPt" Mode 


III 


L-ALL SENT 


I FIELD BITS 
I FIELD BITS IN 
IN PREVIOUS SECOND PREVIOUS ) 
BYTE 
BYTE 


1 
0 
0 
0 
3 
o 
1 
0 
0 
4 
1 
1 
0 
0 
5 
• 
o 
0 
1 
0 
6 
1 
0 
1 
0 
7 
o 1 
1 
0 
8 
1 
1 
1 
1 
8 
o 
0 
0 
2 
8 


PARITY ERROR 
·ReSldue Data For Eight 
Rx OVERRUN ERROR 
Rx Bits/Character Programmed 


L...---CRC/FRAMING ERROR 


~--- END OF FRAME (SDLC) 


tUsed With SpeCial Receive Condition Mode 


READ REGISTER 2* 


III111 ~~:t} 
~;~ 
INTERRUPT 


V4 
VECTOR 
V5 
V6 
, 
V7, 


tVariable If "Status Affects 
Vector" is Programmed 


(·CHANNEL B ONLY) 


Figure 13. Read Register Bit Functions 


2042-0114 


Programming 
(Continued) 


2042·0113 


WRITE REGISTER 0 
I 071 0,1 Os I 0.1 031 0,1 0, I Do I 


1 1 1 


NULL CODE 


REGISTER 0 
REGISTER 1 
REGISTER 2 
REGISTER 3 
REGISTER 4 
REGISTER 5 
REGISTER 6 
REGISTER 7 


SEND ABORT (SDLC) 
RESET EXT/STATUS INTERRUPTS 
CHANNEL RESET 
ENABLE INT ON NEXT R. CHARACTER 
RESET Tx INT PENDING 
ERROR RESET 
RETURN FROM INT (CH·A ONLY) 


NULL CODE 
RESET Rx CRC CHECKER 
RESET Tx CRC GENERATOR 
RESET Tx UNDERRUN/EOM LATCH 


WRITE REGISTER I 
I 071 0,1 Os I 0.1 031 0,1 0, I Do I 
III 
I 1 
EXT INT ENABLE 
Tx INT ENABLE 


'-----STATUS AFFECTS VECTOR 
(CH. B ONLY) 


Rx INT DISABLE 
} 
Rx INT ON FIRST CHARACTER 
INT ON ALL Rx CHARACTERS (PARITY AFFECTS VECTOR) 
• 
INT ON ALL Rx CHARACTERS (PARITY DOES NOT AFFECT 
VECTOR) 
, 


WAIT/READY ON R/T 
WAIT/READY FUNCTION 
'-----WAIT/READy ENABLE 


WRITE REGISTER 2 (CHANNEL B ONLY) 
I 071 0,1 Os I 0.1 031 0,1 0, I Do I 


IIII II ~, 
~~ }INTERRUPT 
~V4 
VECTOR 
, 
V5 
V6 
V7 


WRITE REGISTER 3 
I 071 0,1 Os I 0.1 031 0,1 0, I Do I 


·Or On 
SpecIal 
Condition 


~SYNC 
CHARACTER LOAD INHIBIT 
IIII ' L-,,,,,,,, 


o 
Rx 5 BITS/CHARACTER 


1 Rx 7 BITS/CHARACTER 


1 
0 
Rx 6 BITS/CHARACTER 


1 
Rx 8 BITS/CHARACTER 


ADDRESS SEARCH MODE (SDLC) 
Rx CRC ENABLE 
ENTER HUNT PHASE 
AUTO ENABLES 
. 


WRITE REGISTER 4 
I 071 0,1 0;1 0.1 0, I 0,1 0, I Do I 
I I 


1 
1 
PARITY ENABLE 


' 
PARITY EVEN/ODD 


SYNC MODES ENABLE 
1 STOP BIT/CHARACTER 
1 'I, STOP BITS/CHARACTER 
2 STOP BITS/CHARACTER 


8 BIT SYNC CHARACTER 
16 BIT SYNC CHARACTER 
SDLC MODE (01111110 FLAG) 
EXTERNAL SYNC MODE 


Xl CLOCK MODE 
X16 CLOCK MODE 
X32 CLOCK MODE 
X64 CLOCK MODE 


WRITE REGISTER 5 


[~I~I~I~I~I~I~I~1 
II 


1-1_1 _I __ ~~;RC ENABLE 


. 
SDLC/CRC·16 
'------Tx ENABLE 
'-------SEND BREAK 


T. 5 BITS (OR LESS)/CHARACTER 
Tx 7 BITS/CHARACTER 
T. 6 BITS/CHARACTER 
Tx 8 BITS/CHARACTER 


DTR 


WRITE REGISTER 6 
I 071 0,1 Os I 0.1 0, I 0,1 0, I Do I 


II' 11,1 


1 ~!jmil!}. 
SYNC BIT 5 
SYNC BIT.6 
SYNC BIT 7 


-AlSO SOLe Address Field 


WRITE REGISTER 7 


1~1~1~1~1~1~1~1~1 


SYNC BIT 11 
• 
1II111 ~!~~g::Ho} 
SYNC BIT 12 
SYNC BIT 13 
SYNC BIT 14 
SYNC BIT 15 


·For SOLe 11 Musl Be Programmed 
to "011111 to" For Flag Recognition 


Figure 14. Write Register Bit Functions 
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Timing 
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The SIO must have the same clock as the 


CPU (same phase and frequency relationship, 
not necessarily the same driver). 
Read Cycle. The timing signals generated by 
a 2-80 CPU input instruction to read a data or 
status byte from the SIO are illustrated in 
Figure 15. 
Write Cycle. Figure 16 illustrates the timing 
and data signals generated by a 2-80 CPU out- 
put instruction to write a data or control byte 
into the SIO. 
Interrupt-Acknowledge Cycle. After receiv- 
ing an interrupt-request signal from an 310 
(INT pulled Low), the 2-80 CPU sends an 
interrupt-acknowledge sequence (Ml Low, and 
IORQ Low a few cycles later) as in Figure 17. 
The SIO contains an internal daisy-chained 
interrupt structure for prioritizing nested inter- 
rupts for the various functions of its two chan- 
nels, and this structure can be used within 
an external user-defined daisy chain that 
prioritizes several peripheral circuits. 
The IEI of the highest-priority device is 
terminated High. A device that has an inter- 
rupt pending or under service forces its IEO 
Low. For devices with no interrupt pending or 
under service, IEO = IEI. 
To insure stable conditions in the daisy 
chain, all interrupt status signals are pre- 
vented from changing while Ml is Low. When 
IORQ is Low, the highest priority interrupt 
requestor (the one with IEI High) places its 
interrupt vector on the data bus and sets its 


CLOCK 


CE, CtO, BtA __ 
---I 


~------------------~------------- 


DATA -------------------~~l---- 


Figure 15. Read Cycle 


~ 
~ 
~ 
~ 
~ 


.CO.K 


.... ' •• ~A~~ 


IORQ 
. 
I 


AD -----------------......j.--------- 


~ -------------------~I--------- 


DATA ___________ >G:x ___ __ 


Figure 16. Write Cycle 


internal interrupt-under-service latch. 


Return From Interrupt Cycle. Figure 18 
illustrates the return from interrupt cycle. 
Normally, the 2-80 CPU issues a RET! (Return 
From Interrupt) instruction at the end of an 
interrupt service routine. RET! is a 2-byte 
opcode (EO-40) that resets the interrupt- 
under-service latch in the SIO to terminate the 
interrupt that has just been processed. This is 
accomplished by manipulating the daisy chain 
in the following way. 
The normal daisy-chain operation can be 
used to detect a pending interrupt; however, it 
cannot distinguish between an interrupt under' 
service and a pending unacknowledged inter- 
rupt of a higher priority. Whenever "EO" is 
decoded, the daisy chain is modified by forc- 
ing High the IEO of any interrupt that has not 
yet been acknowledged. Thus the daisy chain 
identifies the device presently under service as 
the only one with an IEI High and an IEO Low. 
If the next opcode byte is "40," the interrupt- 
under-service latch is reset. 


The ripple time of the interrupt daisy chain 
(both the High-to-Low and the Low-to-High 
transitions) limits the number of devices that 
can be placed in the daisy chain. Ripple time 
can be improved with carry-Iook-ahead, or by 
extending the interrupt-acknowledge cycle. 
For further information about techniques for 
increasing the number of daisy-chained 
devices, refer to the Z-80 CPU Product 
Specification. 


CLOCK 


~ \\...--------4:..11 
I 
LV 
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--------_~~ __ 
~I~ 
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Figure 17. Interrupt Acknowledge Cycle 
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Figure 18. Return from Interrupt Cycle 


2044-008, 009, 010, 011 


Absolute 
Maximum 
Ratings 


Test 
Conditions 


DC 
Charac- 
teristics 


Capacitance 


8085-0006 


Voltages on all inputs and outputs 
with respect to GND .......... -0.3 V to + 7.0 V 
Operating Ambient 
As Specified in 
Temperature ........... Ordering Information 
Storage Temperature ........ -65°C to + 150°C 


The characteristics below apply for the 
following test conditions, unless otherwise 
noted. All voltages are referenced to GND 
(0 V). Positive current flows into the refer- 
enced pin. Available operating temperature 
ranges are: 


III S* = O°C to + 70°C, 


+4.75 V ~ Vee ~ +5.25 V 
m E* = - 40°C to + 85°C, 


+4.75 V ~ Vee ~ +5.25 V 


II M* = - 55°C to' + 125°C, 


+4.5 V ~ Vee ~ +5.5 V 


·See Ordering Information section for package 
temperature range and product number. 


Symbol 
Parameter 


VILe 
Clock Input Low Voltage 


VIHe 
Clock Input High Voltage 


VIL 
Input Low Voltage 


VIH 
Input High Voltage 


VOL 
Output Low VC?ltage 


VOH 
Output High Voltage 


ILl 
Input Leakage Current 


IOL 
3-State Output Leakage Current in Float 


IL(SYl 
SYNC Pin Leakage Current 


lee 
Power Supply Current 


Over speCified temperature and voltage range. 


Symbol 
Parameter 
Min 


C 
Clock CapaCitance 


C IN 
Input Capacitance 


COUI 
Output Capacitance 


Over speCified temperature range; f = IMHz 


Stresses greater than those listed under Absolute Maxi- 


mum Ratings may cause permanent damage to the device. 
This is a stress rating only; operation of the device at any 
condition above those indicated in the operational sections 
of these specifications is not implied. Exposure to absolute 
maximum rating conditions for extended periods may affect 
device reliability. 


+5V 


2.1K 


The product number for each operating 
temperature range can be found in the 
ordering information included in the pro- 
duct speCification (see 1982/83 Zilog Data 
Book, document number 00-2034-02). 


Min 
Max 
Unit 
Test Condition 


-0.3 
+0.45 
V 


Vee- 0.6 Vee+ 0.3 
V 
-0.3 
+0.8 
V 


+2.0 
Vee 
V 


+0.4 
V 
IoL = 2.0 rnA 


+2.4 
V 
IoH = -250 p.A 


±10 
p.A 
VIN = 0 to Vee 


±1O 
p.A 
VOUI = 0.4 V to Vee 


+ 10/ -40 
p.A 
O<VIN<Vee 
30 
rnA 


Max 
Unit Test Condition 


40 
pF 
Unmeasured 


5 
pF 
pins returned 


10 
pF 
to ground 
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lSI 
00 o 
(I) ... o 


AC 
Electrical 
Character- 
istics 


CLK 


CE, C/O, o/i 


lORa, RD 


1111 


lEI 


lEO 


INT 


WIRDY 
--®---ltj: " 


Number Symbol 
Parameter 


1 
TcC 
Clock Cycle Time 


2 
TwCh 
Clock Width (High) 


3 
TfC 
Clock Fall Time 


4 
TrC 
Clock Rise Time 
5-TwCl 
Clock Width (Low) 


6 
TsAD(C) 
CE, C/D, BI A to Clock t Setup Time 


7 
TsCS(C) 
IORQ, RD to Clock t Setup Time 


8 
TdC(DO) 
Clock t to Data Out Delay 


9 
TsDl(C) 
Data In to Clock t Setup (Write or Ml Cycle) 
lO-TdRD(DOz)-RD t to Data Out Float Delay 
II 
TdIO(DOl) 
IORQ I to Data Out Delay (INTACK Cycle) 


12 
TsMl(C) 
Ml to Clock t Setup Time 


13 
TsIEI(IO) 
IEI to IORQ j Setup Time (INTACK Cycle) 


14 
TdMl(IEO) 
Ml I to IEO I Delay (interrupt before MI) 
15-TdIEl(IEOr)-IEI t to IEO t Delay (after ED decode) 


16 
TdIEI(IEOf) 
IEI I to IEO I Delay 


17 
TdC(INT) 
Clock t to INT I Delay 


18 
TdIO(W IRWf) IORQ lor CE I to W/RDY I Delay Wait 
Mode) 


19 
TdC(W/RR) 
Clock t to W IRDY I Delay (Ready Mode) 
20-TdC(W/RWz)-Clock I to W/RDY Float Delay (Wait Mode) 


21 
Th 
Any unspecified Hold when Setup is specified 


• Z-80 S10 timings are preliminary and subject to change. 
r Units in nanoseconds (ns). 
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Z-SO SIO 
Z-SOA SIO 
Z-SOB SIO*t 


Min Max 
Min Max 
Min Max 


400 
4000 
250 
4000 
165 
4000 


170 
2000 
105 
2000 
70 
2000 


30 
30 
15 


30 
30 
15 


170-2000--105-2000--70-2000- 


160 
145 
60 


240 
115 
60 


240 
220 
150 


50 
50 
30 


230 
110 
90- 


340 
160 
100 


210 
90 
75 


200 
140 
120 


300 
190 
160 


150 
100 
70- 


150 
100 
70 


200 
200 
150 


300 
210 
175 


120 
120 
100 


150 
130 
110- 


0 
0 
0 


2044-012 


AC 
Electrical 
Character- 
istics 
(Continued) 


Number 
Symbol 


1 
TwPh 


2 
TwPl 


3 
TcTxC 


4 
TwTxC1 
5 
TwTxCh 


6 
TdTxC(TxD) 


TID 


W/ROY 


INT 


RIC 


RID 


W/ROY 


iNT 


SYNC 


Parameter 


Pulse Width (High) 


Pulse Width (Low) 


TkC Cycle Time 


TxC Width (Low) 


TxC Width (High) 


TxC I to TxD Delay (xl Mode) 


7 
T dT xC(W IRRf) 
TxC I to W IRDY I Delay (Ready Mode) 


8 
TdTxC(lNT) 
TxC I to INT I Delay 
9 
TcRxC 
RxC Cycle Time 


10 
TwRxC1 
RxC Width (Low) 


11 
TwRxCh 
RxC Width (High) 


12 
TsRxD(RxC) 
RxD to RxC I Setup Time (xl Mode) 


13 
ThRxD(RxC) 
RxC I to RxD Hold Time (xl Mode) 


14 
TdRxC(W/RRf) 
RxC I to W/RDY I Delay (Ready Mode) 


15 
TdRxC(lNT) 
RxC I to INT I Delay 


16 
TdRxC(SYNC) 
RxC I to SYNC I Delay (Output Modes) 


17 
TsSYNC(RxC) 
SYNC I to RxC I Setup (External Sync 
Modes) 


NOTES: 
1 In all modes, the System Clock rate must be at least live times 
the maximum data rate. 
1. 2-80B SIO timings are preliminary and subject to change. 


2044-013 


N 
00 
C 
Vi ... 
0 


Z-80 SIO 
Z-80A SIO 
Z-80B SIOI 


Min Max 
Min Max 
Min Max 
Notest 


200 
200 
200 
2 


200 
200 
200 
2 


400 
00 
400 
00 
330 
00 
2 


180 
00 
180 
00 
100 
00 
2 


180 
00 
180 
00 
100 
00 
2 


400 
300 
220 
2 
5 
9 
5 
9 
5 
9 
3 
5 
9 
5 
9 
5 
9 
3 


400 
00 
400 
00 
330 
00 
2 


180 
00 
180 
00 
100 
00 
2 


180 
00 
180 
00 
100 
00 
2 
a 
a 
a 
2 


140 
140 
100 
2 


10 
13 
10 
13 
10 
13 
3 


10 
13 
10 
13 
10 
13 
3 


4 
7 
4 
7 
4 
7 
3 


-100 
-100 
-100 
2 


2. Units in nanoseconds (ns). 
3. Units equal to System Clock Periods. 
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Ordering 
Product 
Package/ 
Product 
Package/ 
Information 
Number 
Temp 
Speed 
Description 
Number 
Temp 
Spee~ 
Description 


Z8440 
CE,CM 
2.5 MHz 
Z80 S1010 
Z8441A 
DE,DS 
4.0 MHz 
Z80B S1011 


(40-pin) 
(40-pin) 


Z8440 
CMB,CS 2.5 MHz 
Same as above 
. Z8441A 
PE,PS 
4.0 MHz 
Same as above 


Z8440 
DE,DS 
2.5 MHz 
Same as above 
Z8441B 
CS 
6.0 MHz 
Z80B S10/1 


Z8440 
PE,PS 
2.5 MHz 
Same as above 
(40-pin) 


Z8440A 
CE,CM 
4.0 MHz 
Z80A S1010 
Z8441B 
DS 
6.0 MHz 
Same as above 


(40-pin) 
Z8441B 
PS 
6.0 MHz 
Same as above 


Z8440A 
CMB,CS 4.0 MHz 
Same as above 
Z8442 
CE,CM 
2.5 MHz 
Z80 S10/2 
Z8440A 
DE,DS 
4.0 MHz 
Same as above 
(40-pin) 


Z8440A 
PE,PS 
4.0 MHz 
Same as above 
Z8442 
CMB,CS 2.5 MHz 
Same as above 


Z8440B 
CS 
6.0 MHz 
Z80B S1010 
Z8442 
DE,DS 
2.5 MHz 
Same as above 
(40-pin) 
Z8442 
PE,PS 
2.5 MHz 
Same as above 


Z8440B 
DS 
6.0 MHz 
Same as above 
Z8442A 
CE,CM 
4.0 MHz 
Z80A S10/2 
Z8440B 
PS 
6.0 MHz 
Same as above 
(40-pin) 


Z8441 
CE,CM 
2.5 MHz 
Z80 S10/1 
Z8442A 
CMB,CS 4.0 MHz 
Same as above 
(40-pin) 
Z8442A 
DE,DS 
4.0 MHz 
Same as above 


Z8441 
CMB,CS 2.5 MHz 
Same as above 
Z8442A 
PE,PS 
4.0 MHz 
Same as above 


Z8441 
DE,DS 
2.5 MHz 
Same as above 
Z8442B 
CS 
6.0 MHz 
Z80B S10/2 
Z8441 
PE,PS 
2.5 MHz 
Same as above 
(40-pin) 


Z8441A 
CE,CM 
4.0 MHz 
Z80A S1011 
Z8442B 
DS 
6.0 MHz 
Same as above 
(40-pin) 
Z8442B 
PS 
6.0 MHz 
Same as above 


Z8441A 
CMB,CS 4.0 MHz 
Same as above 


'NOTES: C = Ceramic, D = Cerdip, P = Plastic; E = -40°C to +85°C, M = -55°C to + 125°C, MB = -55°C to + 125°C with 
MIL-STD-883 with Class B processing, S = ooe to + 70°C. 
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Features 


Description 


2044·002, 007 


II Two independent full-duplex channels with 
separate modem controls. Modem status can 
be monitored. 


a In xl clock mode, data rates are 0 to 500K 


bits/second-with a 2.5 MHz clock, or 0 to 
800K bits/second with a 4.0 MHz clock. 


[] Receiver data registers are quadruply buf- 
fered; the transmitter is doubly buffered. 


[] Programmable options include I, I Y2 or 2 
stop bits; even, odd or no parity; and xl, 
xl6, x32 and x64 clock modes. 


The 2-80 DART (Dual-Channel Asynchro- 
nous Receiver/Transmitter) is a dual-channel 
multi-function peripheral component that 
satisfies a wide variety of asynchronous serial 
data communications requirements in micro- 
computer systems. The 2-80 DART is used as a 
serial-ta-parallel, parallel-to-serial converter! 
controller in asynchronous applications. In 
addition, the device also provides modem con- 
trols for both channels. In applications where 


DO 


01 


02 
c.u{ 
0 3 
DATA 


DUS 
0 4 


05 


06 


0 7 


1 


RES~ 


CONTROL 
10: 


F~~~ 
AD 


C/O 


B/A 


DAISY { 
CHAIN 
INTERRUPT 


CONTROL 


iNf 


lEI 


lEO 


RxOA 


RxCA 


TxOA 


IxCA 


W/ROYA 


RISA 


CISA 
} MOOEM 
CONTROL 
f5fRA 
_OCOA 


Z·BO DART 
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Figure 1. Z8D DART Pin Functions 
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m Break generation and detection as well as 
parity-, overrun- and framing-error detec- 
tion are available. 


[lI Interrupt features include a programmable 
interrupt vector, a "status affects vector" 
mode for fast interrupt processing, and the 
standard 2-80 peripheral daisy-chain inter- 
rupt structure that provides automatic inter- 
rupt vectoring with no external logic. 


[lan-chip logic for ring indication and 
carrier-detect status. 


modem controls are not needed, these lines 
can be used for general-purpose I/O. 


2ilog also offers the 2-80 SIO, a more ver- 
satile device that provides synchronous 
(Bisync, HDLC and SDLC) as well as asyn- 
chronous operation. 
The 2-80 DART is fabricated with n-channel 
silicon-gate depletion-load technology, and is 
packaged in a 40-pin plastic or ceramic DIP. 
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Figure 2. Pin Assignments 
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Pin 
Description 
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B/A. Channel A Or B Select (input, High 
selects Channel B). This input defines which 
channel is accessed during a data transfer be- 
tween the CPU and the 2-80 DART. 


C/O. Control Or Data Select (input, High 
selects Control). This input specifies the type 
of information (control or data) transferred on 
the data bus between the CPU and the 2-80 
DART. 


CEo Chip Enable (input, active Low). A Low at 
this input enables the 2-80 DA'RT to accept 
command or data input from the CPU during a 
write cycle, or to transmit data to the CPU 
during a read cycle. 


CLK. System Clock (input): The 2-80 DART 
uses the standard 2-80 single-phase system 
clock to synchronize internal signals. 
CTSA, CTSB. Clear To Send (inputs, active 
·Low). When programmed as Auto Enables, a 
Low on these inputs enables the respective 
transmitter. If not programmed as Auto 
Enables, these inputs may be programmed as 
general-purpose inputs. Both inputs are 
Schmitt-trigger buffered to accommodate slow- 
risetime signals. 


Do-D7. System Data Bus (bidirectional, 
3-state) transfers data and commands between 
the CPU and the 2-80 DART. 
DCDA, DCDB. Data Carrier Detect (inputs, 
active Low). These pins function as receiver 
enables if the 2-80 DART is programmed for 
Auto Enables; otherwise they may be used as 
general-purpose input pins. Both pins are 
Schmitt-trigger buffered. 
DTRA, DTRB. Data Terminal Ready (outputs, 
active Low). These outputs follow the state pro- 
grammed into the DTR bit. They can also be 
programmed as general-purpose outputs. 
lEI. Interrupt Enable In (input, active High) is 
used with IEO to form a priority daisy chain 
when there is more than one interrupt-driven 
device. A High on this line indicates that no 
other device of higher priority is being ser- 
viced by a CPU interrupt 'service routine. 
lEO. Interrupt Enable Out (output, active 
High). IEO is High only if IEI is High and the 
CPU is not servicing an interrupt from this 
• 
2-80 DART. Thus, this signal blocks lower 
priority devices from interrupting while a 
higher priority device is being serviced by its 
CPU interrupt service routine. 
INT. Interrupt Request (output, open drain, 
active Low). When the 2-80 DART is re- 
questing an interrupt, it pulls INT Low, 
MI. Machine Cycle One (input from 2-80 
CPU, active Low). When M1 and RD are both 
active, the 2-80 CPU is fetching an instruction 
from memory; when M1 is active while IORQ is 
active, the 2-80 DART accepts M1 and IORQ 


as an interrupt acknowledge if the 2-80 DART 
is the highest priority device that has inter- 
rupted the 2-80 CPU. 


IORQ. Input/Output Request (input from CPU, 
active Low). IORQ is used in conjunction with 
BIA, ciiS, CE and RD to transfer commands 
and data between the CPU and the 2-80 
DART. When.CE, RD and IORQ are all 
active, the channel selected by BIA transfers 
data to the CPU (a read operation). When CE 
and IORQ are active, but RD is inactive, the 
channel selected by BIA is written to by the 
CPU with either data or control information as 
specified by C/D. 
RxCA, RxCB. Receiver Clocks' (inputs). 
Receive data is sampled on the rising edge of 
RxC. The Receive Clocks may be 1, 16', 32 or 
64 times the data rate, 
RD. Read Cycle Status. (input from CPU, ac- 
tive Low). If RD is active, a memory or I/O 
read operation is in progress. 
RxDA, RxDB. Receive Data (inputs, active 
High). 


RESET. Reset (input, active Low). Disables 
both receivers and transmitters, forces TxDA 
and TxDB marking, forces the modem controls 
High and disables all interrupts. 
RIA, RIB. Ring Indicator (inputs, Active 
Low), These inputs are similar to CTS and 
DCD. The 2-80 DART detects both logic level 
transitions and interrupts the CPU. When not 
used in switched-line applications, these inputs 
can be used as general-purpose inputs. 
RTSA, RTSB. Request to Send (outputs, 
active Low). When the RTS bit is set, the RTS 
output goes Low. When the RTS bit is reset, 
the output goes High after the transmitter 
empties. 


TxCA, TxCB. Transmitter Clocks (inputs). TxD 
changes on the falling edge of TxC. The 
Transmitter Clocks may be 1, 16, 32 or 64 
times the data rate; however, the clock 
multiplier: for the transmitter and the receiver 
must be the same. The Transmit Clock inputs 
are Schmitt-trigger buffered. Both the Receiver 
a'nd Transmitter Clocks may be driven by the 
2-80 CTC Counter Time Circuit for program- 
mable baud rate generation. 
TxDA, TxDB. Transmit Data (outputs, active 
High). 
W/RDYA, W/RDYB. Wait/Ready (outputs,. 
open drain when programmed for Wait func- 
tion, driven High and Low when programmed 
for Ready function). These dual-purpose out- 
puts may be programmed as Ready lines for a 
DMA controller or as Wait lines that syn- 
chronize the CPU to the 2-80 DART data rate. 
The reset state is open drain. 


Functional 
Description 


2044-001 


The functional capabilities of the 2-80 DART 
can be described from two different points of 
view: as a data communications device, it 
transmits and receives serial data, 'and meets 
the requirements of asynchronous data com- 
munications protocols; as a 2-80 family 
peripheral, it interacts with the 2-80 CPU and 
other 2-80 peripheral circuits, and shares the 
data, address and control buses, as well as 
being a part of the 2-80 interrupt structure. As 
a peripheral to other microprocessors, the 2-80 
DART offers valuable features such as non- 
vectored interrupts, polling and simple hand- 
shake capability. 


ComJ;Jlunications Capabilities. The 2-80 
DART provides two independent full-duplex 
channels for use as an asynchronous 
receiver/transmitter. The folloWing is a short 
description of receiver/transmitter capabilities. 
For more detpils, refer to the Asynchronous 
Mode section of the 2-80 510 Technical 
Manual. The 2-80 DART offers transmission 
and reception of five to eight bits per 
character, plus optional even or odd parity. 
The transmitter can supply one, one and a half 
or two stop bits per character and can provide 
a break output at any time. The receiver break 
detection logic interrupts the CPU both at the 
start and end of a received break. Reception is 
protected from spikes by a transient spike re- 
jection mechanism that checks the signal one- 
half a bit time after a Low level is detected on 
the Receive Data input. If the Low does not 
persist-as in the case of a transient-the 
character assembly process is not started. 


I/O Interface Capabilities. The 2-80 DART 
offers the choice of Polling, Interrupt (vectored 
or non-vectored) and Block Transfer modes to 


" transfer data, status and control information to 
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The first part of the following functional 
description introduces Z-80 DART data com- 
munications capabilities; the second part 
describes the interaction between the CPU and 
the 2-80 DART. 
The 2-80 DART offers RS-232 serial com- 
munications support by providing device 
signals for external modem control. In addition 
to dual-channel Request To Send, Clear To 
Send, and Data Carrier Detect ports, the 2-80 
DART also features a dual channel Ring In- 
dicator (RIA, RIB) input to facilitate 
local/remote or station-to-station communica- 
tion capability. 


Framing errors and overrun errors are 
detected and buffered together with the 
character on which they occurred. Vectored 
interrupts allow fast servicirig of interrupting 
conditions using dedicated routines. Further- 
more, a built-in checking process avoids inter- 
preting a framing error a'S a new start bit: a 
framing error results in the addiUon of one-half 
a bit time to the point at which the search for 
the next start bit is begun. 
The 2-80 DART does not require symmetric 
Transmit and Receive Clock signals-a feature 
that allows it to be used with a 2-80 CTC or 
any other clock source. The transmitter and 
receiver can handle data at a rate of I, 1116, 
1132 or 1164 of the clock rate supplied to the 
Receive and Transmit Clock inputs. When 
using Channel B, the bit rates for transmit and 
receive operations must be the same because 
RxC and TxC are bonded together (RxTxCB). 


and from the CPU. The Block Transfer mode 
can be implemented under CPU or DMA 
control. 
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Figure 3. Block Diagram 
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Functional 
Description 
(Continued) 
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POLLING. There are no interrupts in the 


Polled mode. Status registers RRO and RRI are 
updated at appropriate times for each function 
being performed. All the interrupt modes of 
the 2-80 DART must be disabled to operate the 
device in a polled environment. 
While in its Polling sequence, the CPU 


examines the status contained in RRO for each 
channel; the RRO status bits serve as an 
acknowledge to the Poll inquiry. The two RRO 


INTERRUPTS. The 2-80 DART offers an 
elaborate interrupt scheme that provides fast 
interrupt response in real-time applications. As 
a member of the 2-80 family, the 2-80 DART 
can be daisy-chained along with other 2-80 
peripherals for peripheral interrupt-priority 
resolution. In addition, the internal interrupts 
of the 2-80 DART are nested to prioritize the 
various interrupts generated by Channels A 
and B. ChannelB registers WR2 and RR2 con- 
tain the interrupt vector that points to an inter- 
rupt service routine in the memory. To 
eliminate the necessity of writing a status 
analysis routine, the 2-80 DART can modify the 
interrupt vector in RR2 so it points directly to 
one of eight interrupt service routines. This is 
done under program control by setting a pro- 
gram bit (WRl, D2) in Channel B called 
"Status Affects Vector." When this bit is set, 
the interrupt vector in RR2 is modified accord- 
ing to the assigned priority of the various 
interrupting conditions. 
Transmit interrupts, Receive interrupts and 
External/Status interrupts are the main sources 
of interrupts. Each interrupt source is enabled 
under program control with Channel A having 
a higher priority than Channel- B, and with 
Receiver, Transmit and External/Status inter- 
rupts prioritized in that order within each 
channel. When the Transmit interrupt is 
enabled, the CPU is interrupted by the 
transmit buffer becoming empty. (This implies 
that the transmitter must have had a data 
character written into it so it can become 


CPUIDMA BLOCK TRANSFER. The 2-80 


DART prOVides a Block Transfer mode to 
accommodate CPU block transfer functions 
and DMA block transfers (2-80 DMA or other 
designs). The Block Transfer mode uses the 
W IRDY output in conjunction with the 
Wait/Ready bits of Write Register 1. The 
W/RDY output can be defined under software 
control as a Wait line in the CPU Block 


status bits Do and D2 indicate that a data 
transfer is needed. The status also indicates _ 
Error or other special status conditions (see 
"2-80 DART Programming"). The Special 
Receive Condition status contained in RRl, 
does not have to be read in a Polling sequence 
because the status bits in RRI areaccom- 
panied by a Receive Character Available 
status in RRO. 


empty.) When enabled, the receiver can inter- 
rupt the CPU in one of three ways: 


• Interrupt on the first received character 
n Interrupt on all received characters 
.. Interrupt on a Special Receive condition 


Interrupt On Firs,t Character is typically 
used with the Block Transfer mode. Interrupt 
On All Rec~ive Characters can optionally 
modify the interrupt vector in the event of 
a parity error. The Special Receive Condition 
interrupt can occur on a character basis. The 
Special Receive condition can cause an inter- 
rupt only if the Interrupt On First Receive 
Character or Interrupt On All Receive Char- 
acters mode is selected. In Interrupt On First 
Receive Character, an interrupt can occur 
from Special Receive conditions (except Parity 
Error) after the first receive character interrupt 
(example: Receive Overrun interrupt). 
The main function of the ExternaJlStatus 


interrupt is to monitor the signal transitions of 
the CTS, DCD and HI pins; however, an 
External/Status interrupt is also causpd by the 
detection of a Break sequence in the data 
stream. The interrupt caused by the Break 
sequence has a special feature that allows the 
2-80 DART to interrupt when the Break 
sequence is detected or terminated. This 
feature facilitates the proper termination of the 
current message, correct initialization of the 
next message, and the accurate timing of the 
Break condition. 


Transfer mode or as a Ready line in the DMA 
Block Transfer mode. 
To a DMA controller, the 2-80 DART Ready 
output indicates that the 2-80 DART is ready to 
transfer data to or from memory. To the CPU, 
the Wait output indicates that the 2-80 DART is 
not ready to transfer data, thereby requesting 
the CPU to extend the 1/0 cycle. 


Internal 
Architecture 
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The device internal structure includes a 2-80 
CPU interface, internal control and interrupt 
logic, and two full-duplex channels. Each 
channel contains read and write registers, and 
discrete control and status logic that provides 
the interface to modems or other external 
devices. 
The read and write register group includes 
five 8-bit control registers and two status 
registers. The interrupt vector is written into 
an additional 8-bit register (Write Register 2) 
in Channel B that may be read through Read 
Register 2 in Channel B. The registers for both 
channels are designated as follows: 


WRO-WR5 - 
Write Registers 0 through 5 


RRO-RR2 - 
Read Registers 0 through 2 


The bit assignment and functional grouping 
of each register is configured to simplify and 


Data Path. The transmit and receive data path 
illustrated for Channel A in Figure 4 is iden- 
tical for both channels. The receiver has three 
8-bit buffer registers in a FIFO arrangement in 
addition to the 8-bit receive shift register. This 
scheme creates additional time for the CPU to 


RECEIVE 


DATA 


FIFO 
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ERROR 
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organize the programming process. 
The logic for both channels provides for- 


mats, bit synchronization and validation for 
data transferred to and from the channel inter- 
face. The modem control inputs Clear to Send 
(CTS), Data Carrier Detect (DCD) and Ring 
Indicator (RI) are monitored by the control 
logic under program control. All the modem 


, control signals are general purpose in nature 
and can be' used for fu-nctions other than 
modem control. 
For automatic interrupt vectoring, the inter- 


rupt control logic determines which channel 
and which device within the channel has the 
highest priority. Priority is fixed with Channel 
A assigned a higher priority than Channel B; 
Receive, Transmit and External/Status inter- 
rupts are prioritized in that order within each 
channel. 


service a Receive Character Available inter- 
rupt in a high-speed data transfer. 
The transmitter has an 8-bit transmit data 
register that is loaded from the internal data 
bus, and a 9-bit transmit shift register that is 
loaded from the transmit data register. 


TRANSMIT 
2-BIT DELAY 
TxDA 


Figure 4. Data Path 
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Read. 
Write and 
Interrupt 
Timing 
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Read Cycle. The timing signals generated by 
a Z-80 CPU input instruction to read a Data or 


Write Cycle. Figure 5b illustrates the timing 
and data signals generated by a Z-80 CPU out- 


Interrupt Acknowledge Cycle •. After receiv- 
ing an Interrupt Request signal (INT pulled 
Low), the Z-80 CPU sends an Interrupt 
Acknowledge signal (Ml and IORQ both Low). 
The daisy-chained interrupt circuits determine 
the highest priority interrupt requestor. The lEI 
of the highest priority peripheral is terminated 
High. For any peripheral that has no interrupt 
pending or under service, IEO = IEI. Any 
peripheral that does have an interrupt pending 
or under service forces its IEO Low. 


Return From Interrupt Cycle. Normally, the 
Z-80 CPU issues an RET! (Return From Inter- 
rupt) instruction at the end of an interrupt ser- 
vice routine. RET! is a 2-byte opcode (ED-4D) 
that resets the interrupt-under-service latch to 
terminate the interrupt that has just been 
processed. 


M1 --------------------~----------- 


DATA ----------<~)----- 


Figure 5a. ,Read Cycle 


CLOCK 


M1~~ 
______________ 1 


' __ 
-J1 


AD --------------------------------- 
----------.,......----,t"""----- 
lEI. _________ 1 
\ ____ _ 


DATA ------------------<E) ..... --- 


Figure 5c. Interrupt Acknowledg,e Cycle 


Status byte from the Z-80 DART are illustrated 
in Figure 5a. 


put instruction to write a Data or Control byte 
into the Z-80 DART. 


To insure stable conditions in the daisy 
chain, all interrupt status signals are prevented 
from changing while Ml is·Low. When IORQ is 
Low, the highest priority interrupt requestor 
(the one with IEI High) places its interrupt vec- 
tor on the data bus and sets its internal 
interrupt-under-service latch. 
Refer to the Z-80 S10 Technical Manual for 
additional details on the interrupt daisy chain 
and interrupt nesting. 


When used with other CPUs, the Z-80 DART 
allows the user to return from the interrupt 
cycle with a special command called "Return 
From Interrupt" in Write Register 0 of Channel 
A. This command is interpreted by the Z-80 
DART in exactly the same way it would inter- 
pret an RET! command on the data bus. 


AD --------------------------------- 


M1 ----------------------------------- 


DATA ____________ ,JX"-___ 
IN ___ x:= 


Figure 5b. Write Cycle 


IEI------ J 
______ J 


lEO 
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Figure 5d. Return from Interrupt Cycle 
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Z-80 DART 
To program the Z-80 DART, the system pro- 


Programming gram first issues a series of commands that 
initialize the basic mode and then other com- 
mands that qualify conditions within the select- 
ed mode. For example, the character length, 
clock rate, number of stop bits, even or odd 
parity are first set, then the Interrupt mode 
and, finally, receiver or transmitter enable. 


Write Registers. The Z-80 DART contains six 
registers (WRO-WR5) in each channel that are 
programmed separately by the system program 
to configure the functional personality of the 
channels (Figure 4). With the exception of 
WRO, programming the write registers requires 
two bytes. The first byte contains three bits 
(Do-D2) that point to the selected register; the 
second byte is the actual control word that is 
written into the register to configure the Z-80 
DART. 


WRO is a special case in that all the basic 
commands (CMDo-CMD2) can be accessed 
with a single byte. Reset (internal or external) 
initializes the pointer bits Do-D2 to point to 
WRO. This means that a register cannot be 


Read Registers. The Z-80 DART contains 
three registers (RRO-RR2) that can be read to 


. obtain the status information for each channel 
(except for RR2, which applies to Channel B 
only). The status information includes error 
conditions, interrupt vector and standard 
communications-interface signals. 
To read the contents of a selected read 
register other than RRO, the system program 
must first write the pointer byte to WRO in 
exactly the same way as a write register opera- 
tion. Then, by executing an input instruction, 
the contents of the addressed read register can 
be read by the CPU. 


Both channels contain command registers 
that must be programmed via the system pro- 
gram prior to operation. The Channel Select 
input (B/A) and the Control/Data input (C/D) 
are the command structure addressing con- 
trols, and are normally controlled by the CPU 
address bus. 


pointed to in the same operation as a channel 
reset. 


Write Register Functions 


WRO 
Register pointers, initialization commands for 
the various modes, etc. 


WRI 
Transmit/Receive interrupt and data transfer 
mode definition. 


WR2 
Interrupt vector (Channel B only) 


WR3 
Receive parameter:> and control 


WR4 
Transmit/Receive'miscellaneous parameters 
and modes 


WR5 
Transmit parameters and controls 


The status bits of RRO and RRI are carefully 
grouped to Simplify status monitoring. For 
example, when the interrupt vector indicates 
that a Special Receive Condition interrupt has 
occurred, all the appropriate error bits can be 
read from a single register (RRl). 


Read Register Functions 


RRO 
Transmit/Receive buffer status, interrupt 
status and external status 


RRI 
Special Receive Condition status 


RR2 
Modified interrupt vector (Channel B only) 
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Z-80 DART 
Read and Write 
Registers 


READ REGISTER 0 
I D71 D61 D51 D, I D31 D,I D, I Do I 
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READ REGISTER 1 * 


I~I~I~I~I~I~I~I~I 


L-NOTUSED 


PARITY ERROR 
§l§ 


~ 
LALLSENT 


Rx OVERRUN ERROR' 


FRAMING ERROR 


NOT USED 


• Used With Special Receive Condition Mode 


WRITE REGISTER 0 


I~I~I~I~I~I~I~I~I 
T~l 


o 
0 
0 
NULL CODE 
o 
0 
1 
NOT USED 


REGISTER 0 
REGISTER 1 
REGISTER 2 
REGISTER 3 
REGISTER 4 
REGISTER 5 


o 
1 
0 
RESET EXT/STATUS INTERRUPTS 
o 
1 
1 
CHANNEL RESET 
1 
0 
0 
ENABLE INT ON NEXT Rx CHARACTER 
1 
0 
I 
1 
RESET TxlNT PENDING 


1 
1 
0 
ERROR RESET 
1 
1, 
1 
RETURN FROM INT (CH·A ONLY) 
'----------NOTUSED 


WRITE REGISTER 2 (CHANNEL B ONLY) 


I~I~I~I~I~I~I~I~I 
m~ 
'---------- V7 


WRITE REGISTER 4 


I~\~\~\~I~\~\~\~I 


INTERRUPT 
VECTOR 


liIt 


~ 
PARITY ENABLE 


PARITY EVEN/ODD 
. 
o 
0 
NOT USED 
o 
1 
1 STOP BIT/CHARACTER 


~ 
~ 
~ ~T~TpO~I:~Jg~cAHRA,.RC~~~ER 


NOT USED 


o 
0 
Xl CLOCK MODE 
o 
1 
X16 CLOCK MODE 


1 
0 
X32 CLOCK MODE 


1 
1 
X64 CLOCK MODE 


READ REGISTER 2 


INTERRUPT 
VECTOR 


'---------- V7 
"Variable If "Status Affects 
Vector" Is Programmed 


WRITE REGISTER 1 


I~I~\~I~I~\~\~\~I 
T ~ 


L EXT INT ENABLE 
L 
Tx INT ENABLE 
STATUS AFFECTS VECTOR 
(CH. B ONLY) 


o 
1 
Rx INT ON FIRST CHARACTER 
OR ON 
o 
0 
Rx INT DISABLE 
'} 


1 
OINT ON ALL Rx CHARACTERS (PARITY 
SPECIAL 


AFFECTS VECTOR) 
RECEIVE 
INT ON ALL Rx CHARACTERS (PARITY 
CONDITION 
DOES NOT AFFECT VECTOR) 
'------- WAIT/READY ON R/T 


'---,----- WAIT/READY FUNCTION 
L..--,-_--:-___ WAIT/READY ENABLE 


WRITE REGISTER 3 


I~I~I~I~I~I~I~I~I 
T 
I 


I 
L RxENABLE 
L- NOT USED (MUST BE PROGRAMMED 0) 


.... ------ AUTO ENABLES 


'--------- 0 
0 
Rx 5 BITS/CHARACTER 
o 
1 
Rx 7 BITS/CHARACTER 


1 
0 
Rx 6 BITS/CHARACTER 


1 
1 
Rx 8 BITS/CHARACTER 


WRITE REGISTER 5 
I D7\ D6\ D51 D.\ D3\ D,\ D, I Do I 
T ~ 


I L= :~:USED 
~ 
NOTUSED 


Tx ENABLE 


SEND BREAK 
o 
Tx 5 BITS (OR LESS)/CHARACTER 
o 
Tx 7 BITS/CHARACTER 


1 
Tx 6 BITS/CHARACTER 


1 
Tx 8 BITS/CHARACTER 
'------ DTR 
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Absolute 
Maximum 
Ratings 


Test 
Conditions 


DC 
Charac- 
teristics 
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Voltages on all inputs and outputs 
with respect to GND .......... -0.3 V to +7.0 V 
Operating Ambient 
As Specified in 
Temperature ........... Ordering Information 
Storage Temperature ........ -65°C to + 150°C 


The characteristics below apply for the 
following test conditions, unless otherwise 
noted. All voltages are referenced to GND 
(0, V). Positive current flows into the refer- 
enced pin. Available operating temperature 
ranges are: 


[J S* = O°C to + 70°C, 
+4.75V:$ Vee:$ +5.25 V 
c E* = -40°C to +85°C, 


+ 4.75 V:$ Vee:$ + 5.25 V 
c M* = - 55°C to + 125°C, 


+ 4.5 V :$ Vee:$ + 5.5 V 


Symbol 


VILe 
VIHe 
VIL 
VIH 


VOL 
VOH 


IL 


IL(Rl) 


lee 


Parameter 


Clock Input Low Voltage 


Clock Input High Voltage 


Inpllt Low Voltage 
Input High Voltage 
Output Low Voltage 
Output High Voltage 


Inputl3-State Output Leakage Current 


HI Pin Leakage Current 


Power Supply Current 


Stresses greater than those listed under Absolute Maxi- 
mum Ratings may cause permanent damage to the device. 
This is a stress rating only; operation of the device at any 
condition above those indicated in the operational sections 
of these specifications is not implied. Exposure to absolute 
maximum rating conditions for extended periods may affect 
device reliability. 


·See Ordering Information section for package 
temperature range and product number. 


+5V 


Min 
Max 


-0.3 
+0.45 
Vee-0.6 +5.5 


-0.3 
+0.8 
+2.0 
+5.5 
+0.4 


+2.4 
-10 
+10 


-40 
+ 10 


100 


Unit 


V 
V 


V 


V 
V 
V 
p.A 


p.A 


rnA 


2.1K 


Test Condition 


IOL = 2.0 rnA 
IOH = -250 p.A 
O.4<V <2.4V 


O.4<V <2.4V 
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AC 
Electrical 
Charac- 
teristics 


Number Symbol 


1 
TcC 


2 
TwCh 


3 
TfC 


4 
TrC 
5-TwCl 


6 
TsAD(C) 


7 
TsCS(C) 


8 
TdC(DO) 


9 
TsDI(C) 


ClK 


CE, C/D, B/i 


lEI 


lEO 


ii/RDY 


Parameter 


Clock Cycle Time 
Clock Width (High) 
Clock Fall Time 
Clock Rise Time 
Clock Width (Low) 
CE, cin, BfA to Clock t Setup Time 
IORQ, RD to Clock t Setup Time 
Clock t to Data Out Delay 
Data In to Clock t Setup Time (Write or Ml Cycle) 


10-TdRD(DOz)-RD t 'to Data Out Float Delay 


11 
TdIO(DOI) 
IORQ l to Data Out Delay (INTACK Cycle) 


12 
TsMl(C) 
Wto Clock t Setup Time 


13 
TsIEI(IO) 
lEI to IORQ I Setup Time (INTACK Cycle) 


14 
TdMl(IEO) 
WI to lEO I Delay (interrupt before Ml) 
15-TdlEl(IEOr)-.-IEI t to lEO t Delay (after ED decode) 


16 
T dIEI(lEOf) 
lEI I to lEO I Delay 


17 
TdC(lNT) 
Clock t to INT l Delay 


18 
TdIO(W/RWf) IORQ I or CE I to W IRDY I Delay (Wait Mode) 


19 
TdC(W/RR) 
Clock t to W/RDY I Delay (Rfilady Mode) 


20 
TdC(W/RWz) Clock l to W IRDY Float Delay (Wait Mode) 


, • All timings are preliminary and subject to change, 
tUnits in ns, 
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Z-80 DART 
Z-80A DART 
Z-80B DART*t 
Min Max 
Min Max 
Min Max 


400 
4000 
250 
4000 
165 
4000 


170 
2000 
105 
2000 
70 
2000 
30 
30 
15 


30 
30 
15 


170-2000--105-2000-' -70-2000- 


160 
145 
60 


240 
115 
60 


240 
220 
150 


50 
50 
30 


230 
110 
90- 
340 
160 
100 


210 
90 
75 


200 
140 
120 
300 
190 
160 


150 
100 
70- 


150 
100 
70 
200 
200 
150 


300 
210 
175 


120 
120 
100 


150 
130 
110 


AC 
Electrical 
Charac- 
teristics 
(Continued) 
~-- 


Z-80 DART 
Z-80A DART 
Z-80B DARTl 
Number 
Symbol 
Parameter 
Min Max 
Min Max 
Min Max 
Notest 


1 
TwPh 
Pulse Width (High) 
200 
200 
200 
2 
2 
TwPl 
Pulse Width (Low) 
200 
200 
200 
2 
3 
TcTxC 
TxC Cycle Time 
400 
00 
400 
00 
330 
00 
2 
4 
TwTxCl 
TxC Width (Low) 
180 
00 
180 
00 
100 
00 
2 
5-TwTxCh--TxC Width (High) 
180-00--180-00--100-00---2- 


6 
TdTxC(TxD) 
TxC l to TxD Delay 
400 
300 
220 
2 


7 
TdTxC(W/RRf) TxC l to W/RDY l Delay (Ready Mode) 
5 
9 
5 
9 
5 
9 
3 
8 
TdTxC(INT) 
TxC l to INT l Delay 
5 
9 
5 
9 
5 
9 
3 


9 
TcRxC 
RxC Cycle Time 
400 
00 
iOO 
00 
330 
00 
2 
lO-TwRxCI---RxC Width (Low), 
180-00--180-00 
100 
00---2- 


11 
TwRxCh 
RxC Width (High) 
180 
00 
180 
00 
100 
00 
2 


12 
TsRxD(RxC) 
RxD to RxC I Setup Time (xl Mode) 
0 
0 
0 
2 


13 
ThRxD(RxC) 
RxD Hold Time (xl Mode) 
140 
140 
100 
2 


14 
TdRxC(W/RRf) RxC I to W/RDY I Delay (Ready 
10 
13 
10 
13 
10 
13 
3 
Mode) 


15 
TdRxC(INT) 
RxC I to INT l Delay 
10 
13 
10 
13 
10 
13 
3 


NOTES: 
t In all modes, the System Clock rate must be at least live times 
I. Timings are preliminary and subject to change. 
the maximum data rate. RESET must be active a minimum of one 
2. Units in narioseconds (ns). 
complete clock Gycle. 
3. Units equal to System Clock Periods. 
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Product 
Package/ 
Product 
Package/ 
Number 
Temp 
Speed 
Description 
Number 
Temp 
Speed 
Description 


Z8470 
CE 
2.5 MHz 
Z80 DART (40-pin) 
Z8470A 
CS 
4.0 MHz 
Z80A DART 


Z8470 
CM 
2.5 MHz 
Same as above 
(40-pin) 


Z8470 
CMB 
2.5 MHz 
Same as above 
Z8470A 
DE 
4.0 MHz 
Same as above 


Z8470 
CS 
2.5 MHz 
Same as above 
Z8470A 
DS 
4.0 MHz 
Same as above 


Z8470 
DE. 
2.5 MHz 
Same as above 
Z8470A 
PE 
4.0 MHz 
Same as above 


Z8470 
DS 
2.5 MHz 
Same as above 
Z8470A 
PS 
4.0 MHz 
Same as above 


Z8470 
PE 
2.5 MHz 
Same as above 
Z8470B 
CE 
6.0 MHz 
Z80B DART 


Z8470 
PS 
2.5 MHz 
Same as above 
(40-pin) 


Z8470A 
CE 
4.0 MHz 
Z80A DART 
Z8470B 
CS 
6.0 MHz 
Same as above 


(40-pin) 
Z8470B 
DS 
6.0 MHz 
Same as above 


Z8470A 
CM 
4.0 MHz 
Same as above 
Z8470B 
PS 
6.0 MHz 
Same as above 


Z8470A 
CMB 
4.0 MHz 
Same as above 


'NOTES: C = Ceramic, D = Cerdip, P = Plastic; E = -40°C to +85°C, M = -55°C to + 125°C, MB = -55°C to + 125°C with 
MIL-STD-883 Class B processing, S = O°C to + 70°C. 
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Z80 


amil 


Zil 9 


Pioneering the 
Microworld 


Zilog 


Features 


2001-0210,0211 


e The Z80L combines the high performance of 
the Z80 CPU with extremely low power con- 
sumption.' It has the identical pinout and 
instruction set of the Z80. The result is 
increased reliability and lower system power 
requirements. This dramatic power savings 
makes the Z80L a natural choice for both 
hand-held and battery backup applications. 


C The Z80L CPU is offered in two versions: 


Z8300-1-1.0 MHz clock, 15 rnA typical cur- 
rent consumption 
Z8300-3-2.5 MHz clock, 25 rnA typical cur- 
rent consumption 


C The extensiv~ instruction set contains 158 
instructions, resulting in sophisticated data 
handling capabilities. The 78 instructions of 
the 8080A are included as a subset; 8080A 
and Z80 Family software compatibility is 
maintained. 


M1 
Ao 


A, 


MREO 
A2 


OYSTEMI 


lORa 
A3 


CONTROL 
Ro 
A4 


WR 
As 


As 


RFSH 
A7 
ADDRESS 
As 
BUS 


HALT 
Ag 


A,o 


A11 


CPU 1 


zeOL CPU 
A'2 
conTROL 
iNr 
A13 


A14 


A,s 


CPU { 
BUS 
CONTROL 


Figure 1. Pin Functions 


Z8300 Low Power 
Z80L@CPU 
Central Processing iJnit 


Product 
Specification 


September 1983 


II The Z80L microprocessors and associated 
family of peripheral controllers are linked 
by a vectored interrupt system. This system 
can be daisy-chained to allow implementa- 
tion of a priority interrupt scheme. Little, if 
any, additional logic is required for daisy- 
chaining. 


lJ Duplicate sets of both general-purpose and 
flag registers are prOVided, easing the 
design and operation of system software. 
Two 16-bit index registers facilitate program 
proce'ssing of tables and arrays. 


[J There are three modes of high-speed inter: 
rupt processing: 8080 similar, non-Z80 
peripheral device, and Z80 Family 
peripheral with or without daisy chain. 


e On-chip dynamic memory refresh counter. 


All 
A;o 


A'2 
Ag 


A13 
As 


A'4 
A7 


A,s 
As 


ClK 
As 


04 
A4 


03 
A3 


Os 
A2 


Os 
A, 


+5V 
Ao 


02 
GNO 


07 
RFSH 


Do 
M1 


0, 
RESET 


INT. 
BUS REO 


NMI 
WAIT 


HALT 
BUSACK 


MREO 
ViR 


lORa 
AD 


Figure 2. Pin Assignments 
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General 
Description 
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The 280L CPUs are fourth-generation 
microprocessors with exceptional computa- 
tional power. They offer high system 
throughput and efficient memory utilization 
combined with extremely low power consump- 
tion. The internal registers contain 208 bits of 
reacl/write memory that are accessible to the 
programmer. These registers include two sets 
of six general-purpose registers which may be 
used individually as either 8-bit registers or as 
16-bit register pairs. In addition, there are two 
sets of accumulator and flag registers. A group 
of "Exchange" instructions makes either set of 
main or alternate registers accessible to the 
programmer. The alternate set allows operation 
in foreground-background mode or it may be 
reserved for very fast interrupt response. 
The 280L also contains a Stack Pointer, Pro- 


gram Counter, two index registers, a Refresh 
register (counter), and an Interrupt register. 
The CPU is easy to incorporate into a system 
since it requires only a single + 5 V power 


+5V ... 


GND ... 


CLOCK ... 


source, all output signals are fully decoded 
and timed to control standard memory or 
peripheral circuits, and it is supported by an 
extensive family of peripheral controllers. The 
internal block diagram (Figure 3) shows the 
primary functions of the 280L processors. 
Subsequent text provides more detail on the 
280L I/O controller family, registers, instruc- 
tion set, interrupts and daisy chaining, CPU 
timing, and low power requirements. 


ZeOL Low Power Feature. The 280L Family 
offers state-of-the-art microprocessor perfor- 
mance with extremely low power consumption. 
Its low power requirement rivals comparable 
CMOS microprocessors. The 280L Family's 
lower power consumption provides the ability 
to reduce system power requirements and 
enables its use in applications not previously 
possible. The 280L is very well suited to bat- 
tery backup applications or to systems 
operating primarily on batteries in hand-held 
or portable systems. 


~ 
ADun~SS sus 


Figure 3. Z80L CPU Block Diagram 
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Z80L Micro- 
processor 
Family 


Z80L CPU 
Registers 


2001-0213 


The 2ilog 280L microprocessor is the central 
element of a comprehensive microprocessor 
product family. This family works together in 
most applications with minimum requirements 
for additional logic, facilitating the design of 
efficient and cost-effective microcomputer- 
based systems. 
The 280 Family components provide exten- 


sive support for the Z80L microprocessor. 
These are: 


61 The PIO (Parallel Input/Output) operates in 
both data-byte I/O transfer mode (with 
handshaking) and in bit mode (without 
handshaking). The PIO may be config- 
ured to interface with standard parallel 
peripheral devices such as printers, 
tape punches, and keyboards. 


Iil The CTC (Counter/Timer Circuit) features 
four programmable 8-bit counter/timers, 
each of which has an 8-bit pres caler. Each 


Figure 4 shows three groups of registers 
within the 280L CPU. The first group consists 
of duplicate sets of 8-bit registers: a principal 
set and an alternate set (designated by I 
[prime], e.g., A'). Both sets consist of the 
Accumulator Register, the Flag Register, and' 
six general-purpose registers. Transfer of data 
between these duplicate sets of registers is 
accomplished by use of "Exchange" instruc- 
tions. The result is faster response to interrupts 
and easy, efficient implementation of such ver- 
satile programming techniques as background- 


MAIN REGISTER SET 


A 
ACCUMULATOR 
F· FLAG REGISTER 


B 
GENERAL PURPOSE 
C 
GENERAL PURPOSE 


D 
GENERAL PURPOSE 
E 
GENERAL PURPOSE 


H 
GENERAL PURPOSE 
L 
GENERAL PURPOSE 


_8BITS---. 


_---'------16 BITS -------_ 


IX INDEX REGISTER 


IY INDEX REGISTER 


SP STACK POINTER 


PC PROGRAM COUNTER 


I INTERRUPT VECTOR 
I 


R MEMORY REFRESH 


-8BITS---" 


A' 


B' 


D' 


H' 


of the four channels may be configured to 
operate in either counter or timer mode. 


o The DMA (Direct Memory Access) con- 


troller provides dual port data transfer 
operations and the ability to terminate data 
transfer as a result of a pattern match. 


c The SIO (Serial Input/Output) controller 
offers two channels. It is capable of 
operating in a variety of programmable 
modes for both synchronous and asyn- 
chronous communication, including 
Bi-Synch and SDLC. 


CJ The DART_(Dual Asynchronous Receiver/ 
Transmitter) device provides low cost 
asynchronous serial communication. It has 
two channels and a full modem control 
interface. 


t:lI These peripherals are also available in a low 
power version with the exception of the 
DMA. 


foreground data processing. The second set of 
registers consists of six registers with assigned 
functions. These are the I (Interrupt Register), 
the R (Refresh Register), the IX and IY (Index 
Registers), the SP (Stack Pointer), and the PC 
(Program Counter). The third group consists of 
two interrupt status flip-flops, plus an addi~ 
tional pair of flip-flops which assists in identi- 
fying the interrupt mode at any particular 
time. Table 1 provides further information on 
these registers. 


ALTERNATE REGISTER SET 


ACCUMULATOR 
F' 
FLAG REGISTER 


GENERAL PURPOSE 
C' 
GENERAL PURPOSE 


GENERAL PURPOSE 
E' 
GENERAL PURPOSE 


GENERAL PURPOSE 
L' 
GENERAL PURPOSE 


INTERRUPT FlIp·FlOPS 
STATUS 
-[:J 
G-----. 
~ 
INTERRUPTS DISABLED 
STORES IFF1 
4 
~ : 
INTERRUPTS ENABLED 
DURING NMI 
SERVICE 


INTERRUPT MODE FlIP·FlOPS 


IMFa 
IMFb 


INTERRUPT MODE a 
NOT USED 
INTERRUPT MODE 1 
INTERRUPT MODE 2 


Figure 4. CPU Registers 
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zeOL CPU 
Registers 
(Continued) 


Interrupts: 
General 
Operation 
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Register 
Size (Bits) 
Remarks 


A, A' 
Accumulator 
8 
Stores an operand or the results of an operation. 


F, F' 
Flags 
8 
See Instruction Set. 


B, B' 
General Purpose 
8 
Can be used separately or as a 16-bit register with C. 


C, C' 
General Purpose 
8 
See B, above. 


0,0' 
General Purpose 
8 
Can be used separately or as a 16-bit register with E. 


E, E' 
General Purpose 
8 
See 0, above. 


H, H' 
General Purpose 
8 
Can be used separately or as a 16-bit register with L. 


L, L' 
General Purpose 
8 
See H, above. 


Note: The (B,C). (D,E), and (H,L) sets are combined as follows: 
B - 
High byte C - 
Low byte 
0- High byte 
E - 
Low byte 
H - 
High byte 
L - 
Low byte 


Interrupt Register 
8 
Stores upper eight bits of memory address for vectored interrupt 
processing. 


R 
Refresh Register 
8 
Provides user-transparent dynam)c memory refresh. Lower seven 
bits are automatically incremented and all eight are placed on 
the address bus during each instruction felch cycle refresh time. 


IX 
Index Register 
16 
U sed for indexed addressing. 


IY 
Index Register 
16 
Same as IX, above. 


SP 
Stack Poinier 
16 
Holds address of the top of the stack. See Push or Pop in instruc- 
tion set. 


PC 
Program Counter 
16 
Holds address of next instruction. 


IFF\-IFF2 
Interrupt Enable 
Flip-Flops 
Set or reset to indicate interrupt status (see Figure 4). 


IMFa-IMFb 
Interrupt Mode 
Flip-Flops 
' Reflect Interrupt mode (see Figure 4). 


Table I. Z80L CPU Registers 


The CPU accepts two interrupt input signals: 
NMI and INT. The NMI is a non-maskable 
, interrupt and has the highest priority. INT is a 
lower priority interrupt and it requires that 
interrupts be enabled in software in order to 
operate. INT can be connected to multiple 
peripheral devices in a wired-OR 
configuration. 
The Z80L has a single response mode for 
interrupt service for the non-maskable inter-' 
rupt. The maskable interrupt, INT, has three 
programmable response modes available. 
These are: 


II Mode 0 - 
similar to the 8080 micro- 


processor. 


m Mode 1 - 
Peripheral Interrupt service, for 
use with non-8080/Z80 systems. 


I!lI Mode 2 - 
a vectored interrupt scheme, 
usually daisy-chained, for use with Z80 
Family and compatible peripheral devices. 


The CPU services interrupts by sampling the 
NMI and INT signals at the rising edge of the 
last clock of an instruction. Further interrupt 
service processing depends upon the type of 
interrupt that was detected. Details on inter- 
rupt responses are shown in the CPU Timing 
Section. 


Interrupts: 
General 
Operation 
(Continued) 


Non-Maskable Interrupt (NMI). The non- 
maskable interrupt cannot be disabled by pro- 
gram control and therefore will be accepted all 
times by the CPU. NMI is usually reserved for 
servicing only the highest priority type inter- 
rupts, such as that for orderly shutdown after 
power failure has been detected. After 
recognition of the NMI signal (providing 
BUSREQ is not active), the CPU jumps to 
restart location 0066H. Normally, software 
. starting at this address contains the interrupt 
service rou tine. 


Maskable Interrupt (INT). Regardless of the 
interrupt mode set by the user, the Z80L 
response to a maskable interrupt input follows 
a common timing cycle. After the interrupt has 
been detected by the CPU (provided that 
interrupts are enabled and BUSREQ is not 
active) a special interrupt processing cycle 
begins. This is a special fetch (Ml) cycle in 
which IORQ becomes active rather than 
MREQ, as in a normal Ml cycle. In addition, 
this special Ml cycle is automatically extended 
by two WAIT states, to allow for the time 
required to acknowledge the interrupt request 
and to place the' interrupt vector on the bus. 
Mode 0 Interrupt Operation. This mode is 
similar to the 8080 microprocessor interrupt 
service procedures. The interrupting device 
places an instruction on the data bus. This is 
normally a Restart instruction, which will in- 
itiate a call to the selected one of eight restart 
locations in page zero of memory. Unlike the 
8080, the Z80 CPU responds to the Call in- 
struction with only one interrupt acknowledge 
cycle followed by two memory read cycles. 


Modo 1 Interrupt Operation. Mode 1 oper- 
ation is very similar to that for the NMI. The 
principal difference is that the Mode 1 inter- 
rupt has a vector address of 0038H only. 
Mode 2 Interrupt Operation. This interrupt 
mode has been designed to utilize most effec- 
tively the capabilities of the Z80L microproc- 
essor and its associated peripheral family. The 
interrupting peripheral de,vice selects the 
starting address of the interrupt service 
routine. It does this by placing an 8-bit vector 
on the data bus during the interrupt 
acknowledge cycle. The CPU forms a pointer 
using this byte as the lower 8 bits and the con- 
tents of the I register as the upper 8 bits. This 
pOints to an entry in a table of addresses for 
interrupt service routines. The CPU them calls 
the routine at that address. This flexibility in 
selecting the interrupt service routine address 


allows the peripheral device to use several dif- 
ferent types of service routines. These routines 
may be located at any available location in 
memory. Since the interrupting device sup- 
plies the low-order byte of the 2-byte vector, 
bit 0 (Ao) must be a zero. 
Interrupt Priority (Daisy Chaining and 
Nested Interrupts). The interrupt priority of 
each peripheral device is determined by its 
physical location within a daisy-chain config- 
uration. Each device in the chain has an inter- 
rupt enable input line (IEI) and an interrupt 
enable output line (lEO), which is fed to the 


, ,next lower priority device. The first device in 
the daisy chain has its IEI input hardwired to a 
High level. The first device has highest priori- 
ty, while each succeeding device has a cor- 
responding lower priority. This arrangement 
permits the CPU to select the highest priority 
interrupt from several simultaneously interrup- 
ting peripherals. 
The interrupting device disables its lEO line 
to the next lower priority peripheral until it has 
been serviced. After servicing, its IEO line is 
raised, allowing lower priority peripherals to 
demand interrupt servicing. 
The Z80L CPU will nest (queue) any pending 
interrupts or interrupts received while a 
selected peripheral is being serviced. 
Interrupt Enable/Disable Operation. Two' 
flip-flops, IFFl and 1FF2, referred to in the 
register description are used to signal the CPU 
interrupt status. Operation of the two flip-flops 
is described in Table 2. For more details, refer 
to the Z80 CPU Technical Manual and Z80 
Assembly Language Manual. 


Action 
IFFl IFF2 
Comments 


CPU Reset 
0 
0 
Maskable interrupt 
INT disabled 


DI ihstruction 
0 
0 
Maskable interrupt 
execution 
INT disabled 


EI instruction 
Maskable interrupt 
execution 
INT enabled 


LD A,I instruction 
IFF2 - 
Parity flag 
execution 


LD A,R instruction 
IFF2 - 
Parity flag 
execution 


Accept NMI 
0 
IFFj 
IFFj - 
IFF2 
(Maskable inter- 
rupt INT disabled) 


RETN instruction 
IFF2 
IFF2 - 
IFFj at 
execution 
completion of an 
NMI service 
routine. 


Table 2. State of Flip-Flops 
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Instruction 
Set 


8-Bit 
Load 
Group 
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The 280L microprocessor has one of the most 
powerful and versatile instruction sets 
available in any 8-bit microprocessor and 
identical to that of the 280. It includes such 
unique operations as a block move for fast, 
efficient data transfers within memory or 
between memory and I/O. It also allows opera- 
tions on any bit in any location in memory. 
The following is a summary of the 280L 


instruction set and shows the assembly 
language mnemonic, the operation, the flag 
status, and gives comments on each instruc- 
tion. The Z80 CPU Technical Manual 
(03-0029-XX) and Assembly Language 
Programming Manual (03-0002-XX) 
contain significantly more details for 
programming use. 
The instructions in Table 2 are divided into 
the following categories: 
o 8-bit loads 
o 16-bit loads 
o Exchanges, block transfers, and searches 
o 8-bit arithmetic and logic operations 
o General-purpose arithmetic and CPU 


control 


Symbolic 
Flags 
Mnemonic 
Operation 
S 
Z 
H 
P/V 


LD r, r' 
r - 
r' 
X · 


X 
LD r, n 
X · 


X · 


LD r, (HL) 
r - 
(HL) 
X · 


X 
LD r, (IX+d) 
r - 
(IX+d) 
X · 


X 


LD r, (IY+d) 
r - 
(lY +d) 
X 
X 


LD (HL)' r 
(HL) - 
r 
X · 


X 
LD (IX+d), r 
(IX+d) - 
r 
X · 


X 


LD (lY+d), r 
(lY +d) - 
r 
X 
X 


LD (HL)' n 
(HL) - 
n 
X 
X 


LD (IX + d)' n 
(lX+d) - 
n 
X · 


X 


LD (lY +d)' n 
(lY +d) - 
n 
X · 


X 


LD A, (BC) 
A - 
(Be) 
x · x 
LD A, (DE) 
A - 
(DE) 
X 
X · 
LD A, (nn) 
A - 
(nn) 
X · 


X 


LD (Be)' A 
(Be) - 
A 
X · 


X 
LD (DE)' A 
(DE) - 
A 
X 
X 
LD (nn), A 
(nn) - 
A 
X · 


X 


LDA, I 
A - 
I 
X 
0 
X IFF 


LDA, R 
A-R 
X 
0 
X IFF 


LD I, A 
I - 
A 
X 
X 


LDR, A 
R-A 
X 
X. · 


NOTES: r, r' means dny of the registers A, B, C, D, E, H, L. 
IFF the content of the mterrupt enable fllp·flop, (IFF) IS 
copied mto the P/V fldg 
For an explanatIOn of flag notallon and symbols for 


mnemonic tables, see Symbolic NotatIOn section 
following tables. 


N 
C 


o 16-bit arithmetic operations 
o Rotates and shifts 
o Bit set, reset, and test operations 
o Jumps 
o Calls, returns, and restarts 
o Input and output operations 


A variety of addressing modes are 
implemented to permit efficient and fast data 
transfer between various registers, memory 
locations, and input/output devices. These 
addressing modes include: 
o Immediate 
o Immediate extended 
o Modified page zero 
o Relative 
o Extended 
o Indexed 
o Register 
o Register indirect 
o Implied 
o Bit 


Opcode 
No.of 
No.of M No.of T 
76 543 210 Hex By tel 
Cycles States 
Comment. 


01 
r 
r 
~ 
00 
r 
110 
000 
B 
-n- 
001 
C 
01 
r 
110 
7 
010 
D 


II 011 101 
DD 
19 
011 
E 


01 
r 
101 
100 
H 
-d- 
101 
L 


II III 101 
FD 
19 
III 
A 


01 
r 
110 
-d- 


01 110 
r 
7 
II 011 101 
DD 
19 


01 110 
r 
-d- 
II III 101 
FD 
19 


01 110 
r 
-d- 


. 00 110 110 
36 
10 


II 011 101 
DD 
19 


00110110 
36 
-d- 
-n- 


II III 101 
FD 
19 


00 110 110 
36 
-d- 
-n- 


00 001 010 
OA 
7 


00011 010 
IA 
7 


00 III 010 
3A 
13 


00 000 010 
02 
7 


00 010 010 
12 
7 


00 110 010 
32 
13 


-n- 


II 101 101 
ED 


01 010 III 
57 


II 101 101 
ED 


01.011 III 
5F 
II 101 101 
ED 


01 000 III 
47 
II 101 101 
ED 


01 001 III 
4F 


2001·001 


IS-Bit Load 
Group 


Exchange. 
Block 
Transfer. 
Block Search 
Groups 


2001-001 


Mnemonic: 


LD dd. nn 


LD IX, nn 


LDIY, nn 


LD HL, (nn) 


LD dd, (nn) 


LD IX, (nn) 


LD IY, (nn) 


LD (nn). HL 


LD (nn). dd 


LD (nn). IX 


LD (nn). IY 


LD SP, HL 
LD SP, IX 


LD SP, IY 


PUSH qq 


PUSH IX 


PUSHIY 


POP qq 


POP IX 


POP IY 


Symbolic: 
Operation 


dd - 
nn 


IX - 
nn 


IY - 
nn 


H - 
(nn+l) 
L - 
(nn) 


ddH - 
(nn+l) 
ddL - 
(nn) 


IXH - 
(nn+ I) 
IXL - 
(nn) 


IYH - 
(nn+ 1) 


IYL - 
(nn) 


(nn+l) - 
H 
(nn) - 
L 


(nn+ I) - 
ddH 
(nn) - 
ddL 


(nn+ 1) - 
IXH 
(nn) - 
IXL 


(nn+ I) - 
IYH 


(nn) - 
IYL 


SP - 
HL 


SP - 
IX 


SP - 
IY 


(SP-2) - 
qqL 


(SP-I) - 
qqH 


SP - 
SP -2 


(SP-2) - 
IXL 


(SP-I) - 
IXH 


SP - 
SP -2 


(SP-2) - 
IYL 
(SP-I) - 
IYH 
SP - 
SP -2 
qqH - 
(SP+ I) 
qqL - 
(SP) 
SP - 
SP +2 
IXH - 
(SP+ I) 
IXL - 
(SP) 
SP - 
SP +2 


IYH - 
(SP+ I) 


IYL - 
(SP) 
SP - 
SP +2 


S 


NUTES 
del IS dny of the reYlSt"r pdlrs Be. DE. HL. SP. 
qq IS dny of the re<.Jlster Pdlr~ AF. Be. DE. HL 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 
X 


X 


X 


x 


x 


X 


x 


X 


Flag. 
H 
P/V N 
C 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 
X 


X 


X 


x 


x 


X 


x 


X 


Opc:ode 
No.of 
No.of M No.of T 
76 543 210 H.x Byt.. 
Cyc:l.. Stat .. 


00 ddO 001 


-n- 


Il all 101 DD 
00 100 001 21 


-n- 


Il III 101 FD 
00 100 001 21 


-n- 


00 101 010 2A 


II 101 101 ED 
01 ddl all 


-n- 
Il all 101 DD 
00 101 010 2A 


11 111 101 FD 
00 101 010 2A 


00 100 010 22 
-n- 
Il 101 101 ED 
01 ddO all 


11 all 101 DD 
00 100 010 22 


_ n-' 


II III 101 FD 
00 100 010 22 


11 III 001 F9 
II all 101 DD 
II III 001 F9 
II III 101 FD 
11 III 001 F9 
11 qqO 101 


II 011 101 DD 
11 100 101 E5 


11 III 101 FD 
II 100 101 E5 


II qqO 001 


11 all 101 DD 
II 100 001 EI 


11 III 101 FD 
11 100 001 EI 


10 


14 


14 


16 


20 


20 


20 


16 


20 


20 


20 


6 
10 


10 


II 


15 


15 


10 


14 


14 


(PAIH)H. (PAIR)L reler 10 111qh order dnd low order eight b!ts 01 the register Pdlr respectively, 
e.g .. BeL = C. AFH = A 


EX DE, HL 
EX AF. AF' 
EXX 


EX (SP). HL 


EX (SP). IX 


EX (SP). IY 


LDI 


LDIR 


DE - 
HL 
AF - 
AF' 
BC - 
BC' 
DE - 
DE' 
HL - 
HL' 
H - 
(SP+ I) 
L - 
(SP) 


IXH - 
(SP+ I) 


IXL - 
(SP) 
IYH - (SP+ I) 
IYL - 
(SP) 


(DE) - 
(HL) 
DE - 
DE+ I 
HL - 
HL+ I 


BC - BC- I 


(DE) - 
(HL) 
DE - 
DE+I 
HL - 
HL+ I 


BC - BC-I 
Repeat until 
BC = a 


X 
X 
X 


x 


X 


X 


X 
X 
X 


x 


X 


X 


X 
X 


x 
0 x 


NOTE: Q) PlY ffag IS 0 Ii the result 01 Be - 1 = O. otherwise PlY = 1. 


Q) 


CD 


11 101 all EB 
00 001 000 08 
II all 001 D9 


11 100 all E3 


II all 101 DO 
II 100 011 E3 
II III 101 FD 
II 100 011 E3 


II 101 101 ED 
10 100 000 AD 


II 101 101 ED 
10 110000 BO 


19 


23 


23 


16 


21 
16 


Comment. 


dd 
Pair 
~ 
01 
DE 
10 
HL 
11 
SP 


qq 
Pair 
O<JBC 
01 
DE 
10 
HL 
II 
AF 


Register bank and 
auxiliary register 
bank exchange 


Load (HL) into 
(DE). increment 
the pointers and 
decrement the byte 
counter (BC) 
If BC *- 0 
If BC =0 
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Exchange, 
Symbollc 
Flags 
Opcode 
No.of No.of M No.of T 
Block 
Mnemonic 
Operation 
s· Z 
H 
P/V N 
C 
76 543 210 Hex Byte. 
Cyclel State. 
Comment. 


Transfer, 
G) 


Block Search 
LDD 
(DE) - 
(HL) 
x 0 
X 
11 101 101 ED 
16 
Groups 
DE - DE-l 
10 101 000 A8 
HL - HL-l 
(Continlled) 
BC - BC-I 
0 


LDDR 
(DE) - 
(HL) 
x 0 
X 
II 101 101 ED 
21 
IfBC *- 0 


DE - DE-I 
10 III 000 B8 
16 
If BC = 0 


HL - HL-I 
BC - BC-I 
Repeat until 
BC = 0 
G) 
<.i) 
CPI 
A - (HL) 
X 
X 
11 101 101 ED 
16 
HL - 
HL+ 1 
10 100 001 AI 
BC - BC-I 
G) 
CD 
CPIR 
A - (HL) 
X 
X 
I I 101 101 ED 
21 
If BC *- 0 and 
A*- (HL) 
HL - 
HL+ I 
JO 110 001 BI 
16 
IfBC=Oor 
BC - BC-I 
A = (HL) 
Repeat until 
A = (HL) or 
BC = 0 
G) 
CD 
CPD 
A - (HL) 
X 
X 
I I 101 101 ED 
16 
HL - HL-I 
10 101 001 A9 


BC - BC-I 
@ 
CD 
CPDR 
A - (HL) 
X 
X 
II 101 101 ED 
21 
If BC *- 0 and 
A*- (HL) 
HL - HL-I 
10 III 001 B9 
16 
IfBC=Oor 
BC - BC-I 
A = (HL) 
Repeat until 
A = (HL) or 
BC = 0 


NOTES: CD ?IV Ilag IS 0 Ii the result 01 Be - I = 0', otherWise PIV = I. 


Q) P/V flaq 150 dt complelton ollnstruchon only. 
Q) i flag IS 1 Ii A = (HL), otherWise Z = O. 


a-Bit 
ADDA, r 
A-A+r 
X 
X 
V 
10 /QQQJ r 
~ 
Arithmetic 
ADD A, n 
A-A+n 
X 
X 
V 
II 1QQQl11O 
000 B 
and Logical 
001 
C 
010 D 
Group 
ADD A, (HL) 
A - A + (HL) 
X 
X 
V 
10 [QQQ) 110 
7 
011 
E' 
ADD A, (lX+d) A - A + (lX+d) 
X 
X 
V 
II Oil 101 
DD 
19 
100 H 


10 [QQQ) 110 
101 
L 
- 
d - 
III A 
ADD A, (lY + d) A - A + (lY + d) 
X 
X v 0 
I I III 101 
FD 
19 


10 IQQQl 110 
- 
d 


ADCA, s 
A - A+s+CY 
X 
X 
V 
[QQIJ 
s is any of r, n, 


SUB s 
A - A-s 
X 
X v 
lQIQl 
(HL). (IX+d), 
(lY + d) as shown 


SBC A, s 
A - A-s-CY 
X 
X 
V 
IQTI] 
for ADD instruction. 
ANDs 
A-AAs 
X 
X 
P 
[@ 
The indicated bits 


OR s 
A-Avs 
X 
X 
P 
IIill 


replace the IQQQl in 
the ADD set above. 


XOR s 
A-Aes 
X 
X 
P 
[IQiJ 
CPs 
A-s 
X 
X 
V 
[II] 


INC r 
r - r + I 
X 
X 
V 
00 r [QQ] 
INC (HL) 
(HL) -(HL) + I 
X 
X 
V 
00 110 ITilliI 
II 
INC (lX+d) 
(lX+d) - 
X 
X 
V 
II Oil 101 
DD 
23 
(lX+d)+ I 
00 110 [jQQJ 
- 
d - 
INC (lY +d) 
(lY+d) - 
X 
X 
V 
0 
II I II 101 
FD 
23 


(lY +d)+ I 
00 110 [QQ] 


d 
DEem 
m - m-l 
X 
X 
V 
ITQI] 
m Is any of r, (HLl. 
(IX+dl. (lY+d) 
as shown for INC. 
DEC same format 
and states as INC. 
Replace IillQ] with 
!IQIJ in opcode. 
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2001·001 


General- 
Purpose 
Arithmetic 
and 
CPU Control 
Groups 


IS-Bit 
Arithmetic 
Group 


Rotate and 
Shift Group 


2001·001 


Mnemonic 


DAA 


CPL 


Symbolic 
Operation 
S 


Converts acc. content 
into packed BCD 
following add or 
subtract with packed 
BCD operands. 
A-A 


Flags 
H 
P/V N 
C 
x 
X 


X 
X 


NEG 
A-O-A 


CY - CY 


l' X 
X 
V 


CCF 


SCF 
NOP 
HALT 
DI * 
EI * 
IMO 


1M I 


1M2 


CY - 
I 
No operation 
CPU halted 
IFF - 
0 


IFF - 
I 
Set interrupt 
mode 0 


Set interrupt 
mode I 
Set interrupt 
mode 2 


NOTES: 
IFF indicates the interrupt enable flip·flop. 
ey indicates the carry flip~flop. 
• 


X 
X 
X 


X 
X 
X 
X 
X 
X 
X 
X 
X 
X 
X 
X 


X 
X 


X 
X 


* indicates mterrupts a.re not sa.mpled at the end of EI or DI. 


ADD HL, ss 
HL - 
HL+5S 
X 
X 
X 


ApC HL, ss 
HL - 
HL+ss+CY 
1 
X 
X 
X 
V 


SBC HL, ss 


ADD IX, pp 


ADD IY, rr 


INC ss 
INC IX 


INC IY 


DEC ss 
DEC IX 


DECIY 


HL - 
HL-ss-CY 


IX - 
IX + pp 


IY - 
IY + rr 


5S - 
ss + I 
IX - 
IX + I 


IY - 
IY + I 


ss - ss-I 
IX - 
IX-I 


IY - 
IY-I 


NOTES: 
ss IS any of the regISter pairs Be. DE, HL. SP. 
pp IS any of the regISter pairs Be. DE. IX. SP. 
rr IS any of the regISter pairs Be, DE. lY. SP. 


RLCA 


RLA 


RRCA 


RRA 


RLC r 


RLC (HL) 


RLC (IX + d) 
@]..Lt~j]J 
r,(HL).(lX + d).(IY + d) 


RLC (lY +d) 


RL m 
l@j~ 
m"r,(HL).(IX +d).(IY +d) 


RRC m 
L~@] 
mar,(HL).(IX +d).(lY + d) 


X 
X 
X V 


X 
X 
X 


X 
X 
X 


X 
X 


X 


X 
X 


X 


X 


X 


X 


X 


X 
X 


X 


X 
X 


X 


X 


X 


X 


X 


X 
X 


X 
X P 


X 
0 
X 
P 


X 
X 
P 


X 
X 
P 


X 
X 
P 
0 


Opcode 
No.of No.of M No.of T 
76 543 210 Hex Byles 
Cycles Siaies 


00 100 III 27 


00 101 III 2F 


II 101 101 ED 
01 000 100 44 
00 III III 3F 


00 110 III 37 
00 000 000 00 
01 110 110 76 
II 110 011 F3 
II III OIl FB 
II 101 101 ED 
01000 110 46 
II 101 101 ED 
01 010 lID 56 
II 101 101 ED 
01011 110 5E 


00 ssl DOl 


II 101 101 ED 
01 ssl 010 


II 101 101 ED 
01 5S0 010 
II OIl 101 DD 
01 ppl DOl 


II III 101 FD 
00 rrl 001 


00 ssO OIl 
II OIl 101 DD 
00 100 OIl 23 
II III 101 FD 
00 100 Oil 23 
00 5s1 Oil 
II OIl 101 DD 
00 101 Oil 2B 
II III 101 FD 
00 101 Oil 2B 


00000 III 
07 


00010 III 
17 


00 DOl III 
OF 


00011 III 
IF 


II 001 OIl 
CB 


6o[@)r 


11 DOl OIl 
CB 


00 (Q2Q] lID 


II OIl 101 
DD 
II DOl OIl 
CB 
- 
d 
- 


00. (Q2Q] 110 


II III 101 
II 001 011 
- 
d 
- 


00 IQ22] 110 


IQIQ) 


FD 
CB 


·1 


II 


15 


15 


15 


15 


6 
10 


10 


6 
10 


10 


15 


23 


23 


Comments 


Decimal adjust 
accumulator. 


Complement 
accumulator (one's 
complement). 
Negate acc. (two's 
complement). 
Complement carry 
flag. 
Set carry flag. 


~ 
00 
BC 


01 
DE 


10 
HL 
II SP 


pp 
Reg. 


00 
BC 


01 
DE 
10 
IX 
II 
SP 


rr 
Reg. 


00 
BC 


01 
DE 


IDlY 
II 
SP 


Rotate left circular 
accumulator. 


Rotate left 
accumulator. 


Rotate right Circular 


accumulator. 


Rotate right 
accumulator. 


Rotate left circular 
register r. 


~. 
000 
B 


001 
C 


010 
D 


OIl 
E 


100 
H 
101 
L 
III 
A 


Instruction format 
and states are as 
shown for RLC's. 
To form new 
opcode replace 
!QQQ] or RLC's 
with shown code. 
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Rotate and 
Symbolic 
Flags 
Opcode 
No.of 
No.of M No.of T 


Shift Group, 
Mnemonic 
Operation 
5 
Z 
H 
P/V N 
C 
16 543 210 
Hex Bytes 
Cycles States 
Comments 


(Continued) 
RR m 
~@}J 
X 
X 
IQIl] 
ms r,(HL).(IX + d).(IY + d) 


SLA m 
@]~o 
X 
~ 
ms r,(HL).(IX + d).(IY + d) 


SRA m 
~-@] 
X 
X 
Will 
m'" r,(HL).(IX + d).(IY + d) 


SRL m 
o~§] 
X 
X 
OJ] 
m'" r,(HL).(IX + d).(IY + d) 


RLD 
17-413~01 
I~-ol I 
x 
x 
11 101 101 
ED 
18 
Rotate dIgit left and 


A 
(HL) 
01 101 III 
6F 
right between 
the accumulator 


U::=413~01 
1/-8}}01 


and location (HL). 
RRD 
I 
X 
X 
11 101 101 
ED 
18 
The content of the 


A 
(HL) 
01 100 III 
67 
upper half of 
the accumulator is 
unaffected 


Bit Set, Reset 
BIT b, r 
Z - 
rb 
x 
x 
x 
X 
11 001 all CB 
~ 


and Test 
01 
b 
r 
000 B 
BIT b. (HL) 
Z - 
(HL)b 
X 
X 
X 
X 
11 001 all CB 
12 
001 
C 
Group 
01 
b 
110 
010 
D 
BIT b, (IX+d)b Z - 
(IX+d)b 
X 
X 
X 
X 
11 all 101 DD 
20 
all 
E 
11 001 all CB 
100 H 
- 
d - 
101 
L 


01 
b 
110 
III A 


II 'Ill 101 


b 
Bit Tested 
BIT b. (IY + d)b Z - 
(IY + d)b 
X 
X 
X 
X 
FD 
20 
000 
a 
11 001 011 CB 
001 
1 
- 
d - 
010 
2 


01 
b 
110 
all 
3 


100 
4 


101 
5 
110 
6 
111 
7 


SET b, r 
rb - 
1 
X 
X 
II 001 all CB 
8' 


[j] b 


SET b, (HL) 
(HL)b - 
1 
X 
X 
11 001 all CB 
15 


[j] b 
110 
SET b, (IX+d) 
(lX+d)b - 
1 
X 
X 
11 all 101 DD 
23 
II 001 all CB 
- 
d - 
[)J b 
110 


SET b, (IY +d) 
(lY +d)b - 
1 
X 
X 
11 III 101 FD 
23 


11 001 all CB 
- 
d - 
[ITJ b 
110 


RES b, m 
mb - 
a 
x 
x 
lrn 
To form new 


m. r. (HL). 
opcode replace 


OX+d). 
[j] of SET b, s 


OY +d) 
with I@). Flags 
. and time states for 


SET instruction . 


NOTES: 
.The notatJon mh indIcates bit b (0 to 7) or locatlOn m. 


Jump 
IP nn 
PC - 
nn 
X 
X 
11 000 all C3 
10 


Group 
- 
n - 
cc 
Condition 
IP cc, nn 
If condition cc is 
X 
X 
II 
010 
10 
000 
NZ non-zero 
true PC - 
nn, 
001 
Z 
zero 
otherwise 
010 
NC non-carry 
continue 
011 
C 
carry 


100 PO parity odd 
101 
PE parity even 


110 P 
sign positive 
JRe 
PC - 
PC+e 
X 
X 
00 all 000 18 
12 
III M sign negative 


- 
e-2 - 


JR C, e 
If C = 0, 
X 
X 
00 II 1 000 38 
If condition not met. 
continue 
- 
e-2 - 
IfC = 1, 
2 • 
12 
If condition is met. 


PC - 
PC+e 


JR NC, e 
IfC = 1, 
X 
X 
00110000 30 
If condition not met. 
continue 
- 
e-2 - 


If C = 0, 
12 
If condition is met. 


PC - 
PC+e 
IP Z, e 
If Z = a 
x 
x 
00 101 000 28 
If condition not met. 
continue 
- 
e-2 - 


If Z = 1, 
12 
If condition is met. 


PC - 
PC+e 


JR NZ, e 
If Z = 1, 
X 
X 
00 100 000 20 
If co~dition not met. 
continue 
- 
e-2 - 


If Z = 0, 
12 
If condition is met. 


PC - 
PC+e 
IP (HL) 
PC - 
HL 
X 
X 
II 101 001 E9 


IP (IX) 
PC - 
IX 
X 
X 
II all 101 DD 
11 101 001 E9 


110 
2001-001 


Jump Group 
Symbolic 
Flag. 
Opcode 
No.of 
No.of M No.of T 


~Continued) 


Mnemonic 
Oporatlon 
H 
P/V N 
C 
76 5'3 210 Hex 
Bytes 
Cycles 
Statol 
Comment. 


lP (IY) 
PC - 
IY 
X 
X 
11 III 101 FD 
11 101 001 E9 


D1NZ, e 
B - 
B-1 
X 
00 010 000 10 
If B = O. 


If B = 0, 
- 
e-2 - 


contmue 
If B * 0, 
13 
If B * O. 
PC - 
PC+e 


NOTES 
e represents the extensIon In th~ relative addreSSing mode. 
e IS do signed two's complement number In th~ range < - 126, 129> . 
e - 2 In the opcodt:' provides an. eflectlve address 01 pc + e doS PC 15 lncrerr.ented 
by 2 prior to the additIOn at e 


Call and 
CALL nn 
(SP-l) - 
PCH 
X 
X 
11 001 101 CD 
17 
Return Group 
(SP-2) - 
PCL 
PC - 
nn 


CALL cc, nn 
If condition 
X 
X 
11 
cc 100 
10 
If cc is false. 
cc is false 
continue, 
17 
If cc is true. 
otherwise same as 
CALL nn 


RET 
PCL - 
(SP) 
X 
X 
11 001 001 C9 
10 


PCH - 
(SP+ I) 
N 
eo 


RET cc 
If condItion 
X 
X 
11 
cc 000 
If cc is false. 
C 


cc is false 
t"' 


continue, 
11 
If cc is true. 
n 
otherwise 
cc 
Condition 
ir6 


RET 
000 NZ non-zero 
d 
001 Z 
zero 


RET! 
Return from 
X 
X 
11 101 101 ED 
14 
010 NC non· carry 
011 C 
carry 
interrupt 
01 001 101 4D 
100 PO parity odd 
RETNI 
Return from 
X 
X 
11 101 101 ED 
14 
101 PE parity even 
non· maskable 
01 000 101 45 
110 P 
sign positive 
interrupt 
III M 
sign negative 


RST p 
(SP-I) - 
PCH 
X 
X 
11 
t 
III 
·11 
~ 
(SP-2) - 
PCL 
000 
DOH 
PCH - 
0 
001 
OSH 
PCL - 
p 
010 
IOH 
011 
ISH 
100 
20H 


101 
2SH 


110 
30H 
III 
3SH 


NOTE: 
'RETN loads IFF2 - 
IFFI 


Input and 
IN A, (n) 
A - 
(n) 
X 
X 
11 011 011 DB 
11 
n to AD - ·A7 
Output Group 
- 
n - 
Acc. to AS - AI5 


IN r, (C) 
r - 
(C) 
I. 
X 
X 
P 
! 1 101 101 ED 
12 
C to AO - 
A7 
if r = 110 only the 
01 
r 
000 
B to AS - 
AI5 


flags will be affected 


CD 


INI 
(HL) - 
(C) 
X 
X 
X 
X 
X 
X 
11 101 101 ED 
16 
C to AO - 
A7 
B - 
B-1 
@ 
10 100 010 A2 
B to AS - 
AI5 


HL - 
HL + 
INlR 
(HL) - 
(C) 
X 
X 
X 
X 
X 
X 
11 101 101 ED 
5 
21 
C to AO - 
A7 
B - 
B-1 
10 110 010 B2 
(If B*O) 
B to AS - 
AI5 


HL - 
HL + I 
4 
16 
Repeat unhl 
(If B =0) 


B = 0 
CD 


IND 
(HL) - 
(C) 
X 
X 
X 
X 
X 
X 
11 101 101 ED 
16 
C to AD - 
A7 
B - 
B -1 
@ 
10 101 010 AA 
B to AS - 
AI5 


HL - 
HL-I 


INDR 
(HL) - 
(C) 
X 
X 
X 
X 
X 
X 
11 101 101 ED 
5 
21 
C to AD - 
A7 
B - 
B-1 
10 III 010 BA 
(If B*O) 
B to AS - 
A15 
HL - 
HL-l 
4 
16 
Repeat unhl 
(If B =0) 


B = 0 
OUT (n), A 
(n) - 
A 
X 
X 
11 010011 D3 
11 
n to AO - 
A7 
- 
n - 
Acc. to AS - 
AI5 
OUT (C), r 
(C) - 
r 
X 
X 
11 101 101 ED 
12 
C to AO - 
A7 


CD 
01 
r 
001 
B to AS - 
A15 


OUT! 
(C) - 
(HL) 
X 
X 
,X 
X 
X 
X 
II 101 101 ED 
4 - 
16 
C to AO - 
A7 
B - 
B-1 
10 100011 A3 
B to AS - 
A15 
HL - 
HL + I 
@ 
OT!R 
(C) - 
(HL) 
X 
X 
X 
X 
X 
X 
II 101 101 ED 
5 
21 
C to AO - 
A7 
B - 
B-1 
10 110 011 B3 
(If B*O) 
B to AS - 
A15 
HL - 
HL + 
4 
16 
Repedt untd 
(If B=O) 


B = 0 
CD 
OUID 
(C) - 
(HL) 
X 
X 
X 
X 
X 
11 101 101 ED 
16 
C to AO - 
A7 
B - 
B-1 
10 101 011 


HL - 
HL-I 
AB 
B to AS - 
AI5 


NOTE· CD 11 tht· fl'sul! 01 B-1 IS zp.ro Ihp Z flaq IS Sf't, otherWise It lS reset. 
o Z fldq IS 51'! upon instruction compiptlOn only. 
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Input and 
Output Group 
(Continued) 


Summary of 
Flag 
Operation 


Symbolic 
Notation 


112 


Symbolic 
Flags 
Opcode 
No.of No.of M No.of T 
MnemonIc 
Operation 
S 
H 
P/V N 
C 
76 543 210 Hex Bytes 
Cycles States 
Comments 


OTDR 
(C) - 
(HL) 
X 
X 
X 
X 
X 
X 
II 101 101 ED 
5 
21 
. C to Ao - A7 
B - B-1 
10 III Oil 
(If B*O) 
B to Aa - 
AI5 
HL - HL-I 
4 
16 


Repeat until 
(If B=O) 


B = 0 


0, 
Do 
Instruction 
S 
H 
P/V N 
C 
Comments 


ADD A, s; ADC A, s 
X 
X 
V 
0 
a·bit add or add with carry. 


SUB s; SBC A, s; CP s; NEG 
X 
X 
V 
I 
t 
a·blt subtract, subtract with carry, compare and negate accumulator. 
ANDs 
X 
X 
P 
0 
~} 
OR s, XOR s 
X 
X 
P 
0 
Logical operations. 


INC 5 
X 
X 
V 
0 
a·bit Increment. 


DEC 5 
X 
I 
X 
V 
I 
a·bit decrement. 
ADD DD, ss 
X 
X 
X 
0 
16·bit add. 
ADC HL, 55 
X 
X 
X 
V 
0 
16·bit add with carry. 
sac HL, S9 
X 
X 
·X 
V 
I 
16·bit subtract with carry. 
RLA, RLCA,RRA; RRCA 
X 
0 
X 
0 
Rotate accumulator. 
RL m; RLC m; RR m; 
X 
0 
X 
P 
0 
Rotate and shilt locatIOns. 


RRC m; SLA m; 
SRA m; SRL m 
RLD; RRD 
X 
X 
P 
Rotate digit left and right. 
DAA 
X 
I 
X 
P 
Decimal adjust accumulator. 


CPL 
X 
I 
X 
I 
Complement accumulator. 


SCF 
X 
0 
X 
0 
Set carry. 
CCF 
X 
X 
X 
0 
Complement carry. 
IN riC) 
I 
X 
0 
X 
P 
0 
Input register indirect. 
IN!. IND, OUT!; OUTD 
X 
I 
X 
X 
X 
X 
I : } Block input and output. Z = 0 if B * 0 otherwise Z = O. 
INIR; INDR; OT!R; OTDR 
X 
I 
X 
X 
X 
X 
I 
LDI; lOD 
X 
X 
X 
0 
X 
0 : } Block transfer instructions. P/V = I if BC * 0, otherwise PIV = O. 
lOIR; lODR 
X 
X 
X 
0 
X 
0 
CPI; CPIR; CPD; CPDR 
X 
X 
X 
X 
I 
Block search instructions. Z = I if A = (HL). otherwise Z = O. P/V = 


iI BC * 0, otherwise P/V = O. 
lOA, I. lOA, R 
I 
X 
X IFF 
0 
The content of the interrupt enable flip· flop (IFF) is copied into the PIV flag. 
BIT b, s 


Symbol 
S 
Z 
P/V 


H 


N 


H&N 


C 


X 
X 
X 
X 
0 
The state of bit b of location s is copied into the Z flag. 


Operation 
Sign flag. S = 1 if the MSB of the result is I. 
Zero flag. Z = 1 if the result of the operation is O. 
Parity or overflow flag. Parity (P) and overflow 
(V) share the same flag. Logical operations affect 
this flag with the parity of the result while 
arithmetic operations affect this flag with the 
overflow of the result. If P/V holds parity, PlY 
1 if the result of the operation is even, P/V = 0 if 
result is odd. If PlY holds overflow, PlY = 1 if 
the result of the 'operation produced an overflow. 
Half-carry flag. H = 1 if the add or subtract 
operation produced a carry into or borrow from 
bit 4 of the accumulator. 
Add/Subtract flag. N = 1 if the previous opera- 
tion was a subtract. 
Hand N flags are used in conjunction with the 
decimal adjust instruction (DAA) to properly cor- 
feC! the result into packeJ BCD format foHowing 
addition or subtraction using operands with 
packed BCD format. 
Carry/Link flag. C = 1 if the operation produced 
a carry from the MSB of the operand or result. 


Symbol 
I 


o 
1 
X 
V 


P 


ss 


ii 
R 
n 
nn 


Operation 
The flag is affected according to the result of the 
operation. 
The flag is unchanged by the operation. 
The flag is reset by the operation. 
The flag is set by the operation. 
The flag is a "don't care." 
P/V flag affected according to the overflow result 
of the operation. 
PlY flag affected according to the parity result of 
the operation. 
Anyone of the CPU registers A, B, C, D, E, H, L. 
Any 8-bit location for all the addressing modes 
allowed for the particular instruction. 
Any 16-bit location for all the addreSSing modes 
allowed for that instruction. 
Anyone of the two index registers IX or IY. 
Refresh counter. 
8·bit value in range < 0, 255 >. 
16-bit value in range < 0, 65535 >. 


2001·001 


Pin 
Ao-AlS. Address Bus (output, active High, 
Descriptions 
3-state). Ao-A15 form a 16-bit address bus. The 
Address Bus provides the aqdress for memory 
data bus exchanges (up to 64K bytes) and for 
I/O device exchanges. 
BUSACK. Bus Acknowledge (output, active 
Low). Bus Acknowledge indicates to the 
requesting device that the CPU address bus, 
data bus, and control signals MREQ, IORQ, 
RO, and WR have entered their high- 
impedance states. The external circuitry 
can now control these lines. 
BUSREQ. Bus Request (input, active Low). 
Bus Request has a higher priority than NMI 
and is always recognized at the end of the cur- 
rent machine cycle. BUSREQ forces the CPU 
address bus, data bus, and control signals 
MREQ, IORQ, RO, and WR to go to a high- 
impedance state so that other devices can 
control these lines. BUSREQ is normally wire- 
ORed and requires an external pullup for 
these applications. Extended BUSREQ 
periods due to extensive OMA operations can 
prevent the CPU from properly refreshing 
dynamic RAMs. 


00-07. Data Bus (input/output, active High, 
3-state). 00-07 constitute an 8-bit bidirectional 
data bus, used for data exchanges with 
memory and I/O. 


HALT. Halt State (output, active Low). HALT 
indicates that the CPU has executed a Halt 
instruction and is awaiting either a non- 
maskable or a maskable interrupt (with the 
mask enabled) before operation can resume. 
While halted, the CPU executes NOPs to 
maintain memory refresh. 


INT. Interrupt Request (input, active Low). 
Interrupt Request is generated by I/O deVices. 
The CPU honors a request at the end of the 
'current instruction if the internal sbftware- 
controlled interrupt enable flip-flop (IFF) is 
enabled. INT is normally wire-ORed and 
requires an external pullup for these 
applicatiops. 
IORQ. Input/Output Request (output, active 
Low, ~-state). IORQ indicates that the lower 
half of the' address bus holds a valid I/O , 
address for an I/O read or write operation. 
IORQ is also generated concurrently with MI 
during an interrupt acknowledge cycle to indi- 
cate that an interrupt response vector can be 


placed on the data bus. 
MI. Machine Cycle One (output, active Low). 
MI, together with MREQ, indicates that the 
current machine cycle is the opcode fetch 
cycle of an instruction execution. MI, together 
with IORQ, indicates an interrupt acknowledge 
cycle. 
MREQ. Memory Request (output, active 
Low, 3-state). MREQ indicates that the address 
bus holds a valid address for a memory read or 
memory wri,te operation. 


NMI. Non-Maskable Interrupt (input, negative 
edge-triggered). NMI has a higher priority 
than INT. NMI is always recognized at the end 
of the current instruction, independent of the 
status of the interrupt enable flip-flop,' and 
automatically forces the CPU to restart at 
location 0066H. 


RD. Read (output, active Low, 3-state). RD in- 
dicates that the CPU wants to read data from 
memory or an I/O device. The addressed I/O 
device or memory should use this signal to 
gate data onto the CPU data bus., 


RESET. Reset (input, active Low). RESET 
initializes the CPU as follows: it resets the 
interrupt enable flip-flop, clears the PC and 
Registers I and R, and sets the interrupt status 
to Mode O. During reset time, the address and 
data bus go to a high-impedance state, and all 
control output signals go to the inactive state. 
Note that RESET must be active for a minimum 
of three full clock cycles before the reset 
operation is complete~ 
RFSH. Refresh (output, active Low). RFSH, 
together with MREQ, indicates that the lower 
seven bits of the system's address bus can be 
used as a refresh address to the system's 
dynamic memories. 
WAIT. Wait (input, active Low). WAIT 
indicates to the CPU that the addressed mem- 
ory or I/O devices are not ready for a data 
transfer. The CPU continues to enter aWait 
state as long as this signal is active. Extended 
WAIT periods can prevent the CPU from 
refreshing dynamiC memory properly. 


WH. Write (output, active Low, 3-state). WR 
indicates that the CPU data bus holds valid 
data to be stored at the addressed memory or 
I/O location. 
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CPU Timing 
The CPU executes instructions by pro- 
The basic clock period is referred to as a 
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ceeding through a specific sequence of opera- 
tions: 


• Memory read or write 


Ell I/O device read or write 


II Interrupt ackpowledge 


Instruction Opcode Fetch. The CPU places 
the contents of the Program Counter (PC) on 
the address bus at the start of the cycle (Figure 
5). Approximately one-half clock cycle later, 
MREQ goes active. When active, RD indicates 
that the memory data can be enabled onto the 
CPU data bus. 


T, 
T, 
Tw 


CLOCK 


WAIT 
--~----------~--~-fJ~J 


-II-® 


T time or cycle, and three or more T cycles 
make up a machine cycle (Ml, M2 or M3 for 
instance). Machine cycles can be extended 
either by the CPU automatically inserting one 
or more Wait states or by the insertion of one 
or more Wait states by the user. 


The CPU samples the WAIT input with the 
falling edge of clock state 1.'2 .. During clock 
states T3 and T4 of an Ml cycle dynamic RAM 
refresh can occur while the CPU starts 
decoding and executing the instruction. When 
the Refresh Control signal becomes active, 
refreshing of dynamic memory can take place. 


;' 


Do-D7 --}-----f('-~z~....;+Z~.lo.7__:(.f_---Jl'---_=f ...... _______ +-__ _ 
~ 
'-'" 
I 
- 


____ 
OI/ _ _ 
I-r 


21 
~22 


RFSH 
r-- 
--------' 


NOTE: Tw-Wait cycle added when necessary for slow ancilliary devices. 


Figure 5. Instruction Opcode Fetch 
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CPU 
Timing 
(Continued) 
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Memory Read or Write Cycles. Figure 6 
shows the timing of memory read or write 
cycles other than an opcode fetch (Ml) cycle. 
The MREQ and RD signals function exactly as 
in the fetch cycle. In a memory write cycle, 


T, 


CLOCK 


{ 


RD 


OPERA~~~~ 


00- 0 7 


OPER~:IIJ~ 


MREQ also becomes active when the address 
bus is stable. The WR line is active when the' 
data bus is stable, so that it can be used 
directly as an R/W pulse to most semiconduc- 
tor memories. 


{ 


\'iR 


00- 
0 
7 --------------~--------~~--------------------~ 


Figure 6. Memory Read or Write Cycles 
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CPU 
Timing 
(Continued) 
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Input or Output Cycles. Figure 7 shows the 
timing for an I/O read or I/O write operation. 
During I/O operations, the CPU automatically 


inserts a single Wait state (Tw). This extra Wait 
state allows sufficient time for an I/O port to 
decode the address from the port address lines. 


CLOCK 


Ao-A7 __ +-J1Y-__ ~ 
____________ ~~~ 
__ -H ________ H-+-~~''-_ 


WAIT __ ~ 
__ 4-__ ~ 
__________ ~ 
__ L-~~_' 


110 { 
READ 
OPIRATION 


{ 


WR 


WRI~~ 


OPERATION 
---------~r---------------~{~------~~;_----__\ 
00- 0 7 
~ 
DATA OUT 


I~ _____________ I):"-_________ .....J .... ®.- 
~ 


NOTE: Tw· = One Wait cycle automatically inserted by CPU. 


Figure 7. Input or Output Cycles 


Interrupt Request/Acknowledge Cycle. The 
CPU samples the interrupt signal :with .the ris- 
ing edge of the last clock cycle at the' end of 
any instruction (Figure 8). When an interrupt 
is accepted, a special Ml cycle is generated. 


During this Ml cycle, IORQ becomes active 
(instead of MREQ) to indicate that the inter- 
rupting device can place an 8-bit vector on the 
data bus. The CPU automatically adds two 
Wait states to this cycle. 


Tw' 
Tw' 
Tw 


CLOCK 


-----I----\.I----+----+H:~~-~ 


Ao-A15 ____________ ~~r1--------------p~c~~------_H_{.~--~+_~+_-'.~--- 


WAIT ____________ ~--------------------------~--~~J 


00-07 


NOTE: I) TL = Last state 01 previous instruction. 
2) Two Wait cycles automatically inserted by CPU(·). 


Figure 8. Interrupt Request/Acknowledge Cycle 


2005-884, 885 


CPU 
Timing 
(Continued) 
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Non-Maskable Interrupt Request Cycle. 
NMI is sampled at the same time as the 
maskable interrupt input INT but has higher 
priority and cannot be disabled under software 
control. The subsequent timing is similar to 


CLOCK 


IlMl - - 
- 
- 
- 
- ~ ® Ir --- 
-------+-1------ 


that of a normal memory read operation except 
that data put on the bus by the memory is 
ignored. The CPU instead executes a restart 
(RST) operation and jumps to the NMI service 
routine located at address 0066H (Figure 9). 


.la-AU -------------1-' -l-4---...;..;;""..---+-"+o-----+---+-----4J 


• Although NMI is an asynchronous input. to ~antee its being 
recognized on the following machine cycle, NMI's falling edge 
must occur no later than the rising edge of the clock cycle 
preceding TLAST. 


Figure 9. Non-Maskable Interrupt Request Operation 


Bus Request/Acknowledge Cycle. The CPU 
samples BUSREQ with the rising edge of the 
last clock period of any machine cycle (Figure 
10). If BUSREQ is active, the CPU sets its 
address, data, and MREQ, IORQ, RD, and WR 


CLOCK 


BUSREQ 


BUSACK 


--® 


Ao-A15 


-@ 


00-07 


--@ 


MREQ 
AD ,ViR 


IORQ 


Ml 


-®-- 


NOTE' TL = Last state of any M cycle. 


lines to a high-impedance state with the rising 
edge of the next clock pulse. At that time, any 
external device can take control of these lines, 
usually to transfer data between memory and 
I/O devices. 


FLOAT 


FLOAT 


UNCHANGED 


TX = An arbitrary clock cycle used by requesting device. 


Figure 10. Z-BUS Request/Acknowledge Cycle 
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Halt Acknowledge Cycle. When the CPU 
receives a HALT instruction, it executes NOP 
states until either an INT or NMI input· is . 


received. When in the Halt state, the HALT 
output is active and remains so until an inter- 
rupt is processed (Figure 11). 


Ml ----.I •• --------Ml-------~.I 
•• ------ Ml 
T4 
Tl 
T2 
T3 
T4 
Tl 
T2 


CLOCK 


-------------------------- I--~_·--------------------- 
NMI 
U- 


NOTE: lNT will also force a Halt exit. 
• See note, Figure Q. 


Figure 11. Halt Acknowledge Cycle 


Reset Cycle. RESET must be active for at least 
three clock cycles for the CPU to properly 
accept it. As long as RESET remains active, the 
address and data buses float, and the control 
outputs are inactive. Once RESET goes 


CLOCK 


-®- 


inactive, two internal T cycles are consumed 
before the C'PU resumes normal processing 
operation. RESET clears the PC register, so the 
first opcode fetch' will be to location 0000 
(Figure 12). 


I.._---Ml--- - 
- 
- 


-0- 


FLOAT 


-----------------------®J- 
0 
0-07 
~~------------------------~-------------------- 


FLOAT 
-®- 


M1 
/ 


----------------------~ 


: 


~R~ 
R~~------------~/Z~/~/~/~/~/~-----~'~)-----------------------\-------------- 


BU~~~~ 
------ 
~--------------- 


HALT 


Figure 12. Reset Cycle 
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AC 
Z8300-1 
Z8300-3 


Charac- 
(1.0 MHz) 
(2.5 MHz) 
teristicst 
Min 
Max 
Min 
Max 
Number Symbol 
Parameter 
(ns) 
(ns) 
(ns) 
(ns) 


TcC 
Clock Cycle Time 
1000* 
400* 


2 
TwCh 
Clock Pulse Width (High) 
470* 
180* 


3 
TwCl 
Clock Pulse Width (Low) 
470 
2000 
180 
2000 


4 
TfC 
Clock Fall Time 
30 
30 


5-TrC 
Clock Rise Time 
30 
30 


6 
TdCr(A) 
Clock' to Address Valid Delay 
380 
145 


7 
TdA(MREQf) 
Address Valid to MREQ 
370* 
125* 


I Delay 


8 
T dCf(MREQf) 
Clock I to MREQ I Delay 
260 
100 


9 
TdCr(MREQr) 
Clock , to MREQ " Delay 
260 
100 


lO-TwMREQh--MREQ Pulse Width (High) 
410* 
170*--- 


11 
TwMREQl 
MREQ Pulse Width (Low) 
890* 
360* 
tl 


12 
TdCf(MREQr) 
Clock I to MREQ , Delay 
260 
100 
0 
t'II 


13 
TdCf(RDf) 
Clock I to RD I Delay 
340 
130 
~ 
.., 


14 
TdCr(RDr) 
. Clock , to RD , Delay 
260 
100 
CI 


15-TsD(Cr)---Data Setup Time to Clock' 
140 
50 


16 
ThD(RDr) 
Data Hold Time to RD , 
0 
0 


17 
TsWAIT(Cf) 
WAIT Setup Time to Clock I 
190 
70 


18 
ThWAIT(Cf) 
WAIT Hold Time after Clock I 
0 
0 


19 
TdCr(Mlf) 
Clock' to MI I Delay 
340 
130 
20- TdCr(Mlr)--Clock , to Ml , Delay 
340 
130 


21 
TdCr(RFSHf) 
Clock , to RFSH I Delay 
460 
180 


22 
TdCr(RFSHr) 
Clock 1 to RFSH , Delay 
390 
150 


23 
TdCf(RDr) 
Clock I to RD , Delay 
290 
110 


24 
TdCr(RDf) 
Clock' to RD I Delay 
260 
100 


25-TsD(Cf) 
Data Setup to Clock I during 
160 
60 
M21 M31 M4 or M5 Cycles 


26 
TdA(IORQf) 
Address Stable prior to lORQ 
790* 
320* 


27 
TdCr(lORQf) 
Clock , to lORQ I Delay 
240 
90 


28 
TdCf(IORQr) 
Clock I to lORQ , Delay 
290 
110 


29 
TdD(WRf) 
Data Stable prior to WR I 
470* 
190* 
30-TdCf(WRf)--Clock I to WR I Delay 
240 
90 


31 
TwWR 
WR Pulse Width 
890* 
360* 


32 
TdCf(WRr) 
Cloyk I to WR , Delay 
260 
100 


33 
TdD(WRf) 
Data Stable prior to WR I 
-30* 
30* 


34 
TdCr(WRf) 
Clock , to WR I Delay 
210 
80 


35 - 
TdWRr(D) -- Data Stable from WR , 
290* 
130*--- 


36 
TdCf(HALT) 
Clock I to HALT' or I 
760 
300 


37 
TwNMl 
NMI Pulse Width 
210 
80 


38 
TsBUSREQ(Cr) BUSREQ Setup Time to Clock' 
210 
80 


• For clock periods other than the minimums shown in the table, calculate parameters 
using the expressions in the table on the following page. 
tAIl timings assume equal loading on pins within 50 pF. 
Timings are preliminary and subject to change. 
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Number Symbol 
Parameter 


39 
ThBUSREQ(Cr) 
BUSREQ Hold Time after Clock I 


40 -TdCr(BUSACKf)- Clock I to BUSACK 1 Delay 


41 
TdCf(BUSACKr) Clock 1 to BUSACK I Delay 
42 
TdCr(Dz) 
Clock I to Data Float Delay 
43 
TdCr(CTz) 
Clock I to Control Outputs Float 
Delay (MREQ, IORQ, RD, 
and WR) 
44 
TdCr(Az) 
Clock I to Address Float Delay 
45-TdCTr(A)--MREQ I, IORQ I, RD I, and 
WR I to Address Hold Time 
46 
TsRESET(Cr) 
RESET to Clock I Setup Time 
47 
ThRESET(Cr) 
RESET to Clock I Hold Time 
48 
TsINTf(Cr) 
INT to Clock I Setup Time 
49 
ThINTr(Cr) 
INT to Clock I Hold Time 


50 -TdMlf(IORQf) - 
M1 1 to IORQ 1 Delay 


51 
TdCf(IORQf) 
Clock 1 to IORQ 1 Delay 
52 
TdCf(IORQr) 
Clock I to IORQ I Delay 
53 
TdCf(D) 
Clock 1 to Data V alid D~lay 


'For clock periods other than the minimums shown in the table, calculate parameters 
using the following expressions. Calculated values above assumed TrC = TIC = 20 ns. 
t All timings assume equal loading on pins with 50 pF. 
Timings are preliminary and subject to cha·nge. 


Footnotes to AC Characteristics 


Number Symbol 


1 


2 


TeC 


TwCh 


Z8300-1 


TwCh + TwCl + TrC + TfC 


Although static by design, 
TwCh of greater than 200 J1.s 
is not guaranteed 


Z8300-1 


Min 
Max 
(ns) 
(ns) 


0 
310 


290 
240 


290 


290 
400* 


240 
0 


210 


0 
2300* 


290 
260 


290 


Z8300-3 


TwCh + TwCl + TrC + TfC 


Although static by design, 
TwCh of greater than 200 J1.S 
is not guaranteed 


Z8300-3 


Min 
Max 
(ns) 
(ns) 


0 
120 


110 
90 


110 


110 


160*-- 


90 
0 
80 
0 
920*-- 


110 


100 
230 


7 -. TdA(MREQf) ---- TwCh + TfC - 
200 ------ TwCh + TfC - 
75 -------- 


10 
TwMREQh 
TwCh + TfC - 
90 
TwCh + TfC - 
30 


11 
TwMREQl 
T eC - 
110 
TeC - 
30 


26 
TdA(IORQf) 
TeC - 
210 
TeC - 80 


29 
TdD(WRf) 
TeC - 
540 
TeC - 
210 
31- TwWR ------- TeC - 
110 
TeC - 
40 ------------ 


33 
TdD(WRf) 


35 
TdWRr(D) 


45 
TdCTr(A) 


50 
TdM1f(IORQf) 


AC Test Conditions: 
VIH = 2.0 V 
VIL = 0.8 V 
VIHC = VCC -0.6 V 
VILC = 0.45 V 
VOH = 2.0 V 
VOL = 0.8 V 
FLOAT = ±0.5 V 


TwCl + TrC - 
470 
TwCl + TrC - 
180 


TwCl + TrC - 210 
TwCl + TrC - 80 


TwCl + TrC - 
110 
TwCl + TrC - 
40 


2TeC + TwCh + TfC - 
210 
2TeC + TwCh + TfC - 
80 


Absolute 
Maximum 
Ratings 


Standard 
Test 
Conditions 


DC 
Charac- 
teristics 


Storage Temperature ........ -65°C to + 150 °e 
Temperature 
under Bias ........ See Ordering Information 
Voltages on all inputs and 


<;mtputs with respect to ground. -0.3 V to + 7 V 
Power Dissipation .................... 1.5 W 


The characteristics below apply for the 
folloWing standard test conditions, unless 
otherwise noted. All voltages are referenced to 
GND (0 V). Positive current flows into the 
referenced pin. Available operating 
temperature ranges are: 
m S* = ooe to + 70°C, 


+4.75 V ::5 Vee::5 +5.25 V 


'See Ordering Information section for package 
temperature range and product number. 


Symbol 


VILe 


VIHe 
VIL 


VIH 


VOL 


VOH 
III 


lLO 
lee 


Parameter 


Clock Input Low Voltage 


Clock Input High Voltage 


Input Low Voltage 


Input High Voltage 


Output Low Voltage 
Output High Voltage 


Input Leakage Current 


3-State Output Leakage 


Power Supply Current 


Frequency 


28300-1 (1.0 MHz) 


28300-3 (2.5 MHz) 


OOC 
Max 


30 


45 


Capacitance 
Symbol 
Parameter 


Stresses greater than those listed under Absolute Maxi- 


mum Ratings may cause permanent damage to the device. 
This is a stress rating only; operation of the device at any 
condition above those indicated in the operational sections 
of these specifications is not implied. Exposure to absolute 
maximum rating conditions for extended periods may affect 
device reliability. 


All ac parameters assume a load capacitance 
of 100 pF. Add 10 ns delay for each 50 pF in- 
crease in load up to a maximum of 200 pF for 
the data bus and 100 pF for address and control· 
lines. 


+5V 


Min 
Max 
Unit 
Test Condition 


-0.3 
0.45 
V 


Vee-·6 Vee+ .3 
V 
-0.3 
0.8 
V 


2.0 
Vee 
V 


0.4 
V 
IoL= 1.8 rnA 
2.4 
V 
IoH = -250 p.A 


10 
J.l.A 
VIN = 0 to Vee 


± 101 
J.l.A 
VOUT = 0.4 to Vee 


Temperature 


25°C 
70°C 


Max 
Typical 
Max 
Unit 


26 
15 
20 
rnA 


42 
25 
35 
rnA 


Min 
Max 
Unit 
Note 


------------------~----------------------------------------------------------- 


8085-0221 


CeLOeK 
CIN 
COUT 


Clock Capacitance 


Input Capacitance 
Output Capacitance 


TA = 25°e. f = 1 MHz. 


35 


5 


10 


pF 


pF 
U nrneasured pins 


pF 
returned to ground 
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Ordering 
Product 
Package/ 
Product 
Package/ 
Information 
Number 
Temp 
Speed 
Description 
Number 
Temp 
Speed 
Description 


28300-1 
PS 
1.0 MHz 
280L CPU (40-pin) 
28300-3 
PS 
• 2.5 MHz 
280L CPU (40-pin) 


28300-1 
CS 
1.0 MHz 
Same as above 
28300-3 
CS 
2.5 MHz 
Same as above 


NOTES: C = Ceramic, P = Plastic; S = O°C to + 70°C. 
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00-2189~4 


Ziiog 


Absolute 
Maximum 
Ratings 


Test 
Conditions 


DC 
Charac- 
teristics 


Voltages on all inputs and outputs 
with respect to GND .......... -0.3 V to + 7.0 V 


As Specified in 
Operating Ambient 
Ordering Information 
Temperature ........ in Product Specifications 
Storage Tempera ture ........ -65°C to + 150 °C 


The characteristics below apply for the 
following test conditions, unless otherwise 
noted. All voltages are referenced to GND 
(0 V). Positive current flows into the refer- 
enced pin. Available operating temperature 
range is: 


[J S * = O°C to + 70°C, 
+4.75Vs;Vee s; +5.25 V 


·See Ordering Information section in· product specifications 
for package temperature range and product number. 


Symbol 
Parameter 
Min 


VILe 
Clock Input Low Voltage 
-0.3 


VIHe 
Clock Input High Voltage 
Vee- 0.6 


VIL 
Input Low Voltage 
-0.3 


VIH 
Input High Voltage 
+2.0 


VOL 
Output Low Voltage 


VOH 
Output High Voltage 
+2.4 
ILl 
Input Leakage Current 


ILO 
3-State Output Leakage 
Current in Float 
IL(Sy)l 
SYNC Pin Leakage Current 


lee 
Power Supply Current: 


SIO 
PIO 
CTC 
IOHD2 
Darlington Drive Current 
-1.5 


Over specified temperature and voltage range. 


NOTES: 


[1] SIO only 
[2] eTe and PIa only 


2:8320 )Low Power 
ZaOL ® PIO Parallel 


Kmlpu~/@uRpui 


1I.e and DC Characteristics 


Preliminary 


September 1983 


Stresses greater than those listed under Absolute Maxi- 
mum Ratings may cause permanent damage to the device. 
This is a stress rating only; operation of the device at any 
condition above those indicated in the operational sections 
of these specifications is not implied. Exposure to absolute 
maximum rating conditions for extended periods may affect 
device reliability. 


Max 
Typical 


+0.45 
Vee+ 0.3 


+0.8 
Vee 
+0.4 


±1O 


±1O 
+10/ -40 


30 
20 
20 
13 


20 
13 


Unit 


V 
V 
V 
V 
V 
V 
/lA 


/lA 
/lA 


rnA 
rnA 
rnA 
rnA 


+5V 


2.1K 


Condition 


loL = 2.0 rnA 
IOH = -250/lA 
VIN = 0 to Vee 


VOUT = 0.4 to Vee 
VIN = 0 to Vee 


VOH = 1.5V 
REXT = 390n 
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Z8320-1 and 
Z8320-3 
Z80L PIO 
AC 
Characteristics 


CLOCK 


CE 


B/A,C/D 


DO-D7 {OUT ___ -+-~ Ir-----+-----"""""II ,.-++--__ 
+--__ 
_ 


IN 
------~----~--~.~---+---------------~ 
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lEI 


lEO 


READY 
IARDY OR BRDY) 


STROBE 
IASTB OR BSTB) 


Ao-A7 
Bo-B7 


MODE 0 


MODE 1 


MODE2 


MODE 3 


I.-------~QD~------~~I 
r---~----------------------- 


Z8320-1 and 
Z8320-l 
Z8320-3 


Z8320-3 
(1.0 MHz) 
(2.5 MHz) 


Z80L PIO 
Number Symbol 
Parameter 
Min 
Max 
Min 
Max 
Notes* 


AC 
TcC 
Clock Cycle Time 
1000 
400 
[ 1) 
Characteristics 
2 
TwCH 
Clock Width (High) 
470 
2000 
170 
2000 
(Continued) 
3 
TwCl 
Clock Width (Low) 
470 
2000 
170 
2000 


4 
TfC 
Clock Fall Time 
30 
30 


5-TrC 
Clock Rise Time 
30 
30 


6 
TsCS(RI) 
CE, BIA, C/iS to RD, 


IORQ 1 Setup Time 
140 
50 
[6) 


7 
Th 
Any Hold Times for Specified 
Setup Time 
0 
0 


8 
TsRI(C) 
RD, IORQ to Clock I Setup 
Time 
300 
115 
9 - 
TdRI(DO) -- RD, lORQ 1 to Data Out Delay 
1090 
430--- [2)-- 


10 
TdRI(DOs) 
RD, IORQ I to Data Out Float 
Delay 
410 
160 
I 
11 
TsDI(C) 
Data In to Clock I Setup Time 
140 
50 
CL = 50 pF 
til 


12 
TdIO(DOl) 
IORQ 1 to Data Out Delay 
• 
(lNTACK Cycle) 
860 
340 
(3) 
IllS 


13 - 
TsMl(Cr) -- Ml 1 to Clock I Setup Time 
540 
210 
0 


14 
TsMl(Cf) 
Ml I to Clock 1 Setup Time 
(Ml Cycle) 
0 
0 
[8) 


15 
TdMl(lEO) 
Ml 1 to lEO 1 Delay (Interrupt 
Immediately Preceding Ml I) 
760 
. 300 
[5,7) 


16 
TslEI(lO) 
lEI to IORQ 1 Setup Time 
(lNTACK Cycle) 
360 
140 
(7) 


17 - 
TdlEI(lEOf) -lEI 1 to lEO 1 Delay 
480 
190--(5)-- 
CL = 50 pF 


18 
TdlEl(lEOr) 
lEI I to lEO I Delay (after ED 
Decode) 
540 
210 
(5) 


19 
TcIO(C) 
IORQ I to Clock 1 Setup Time 
(To Activate READY on Next 
Clock Cycle) 
560 
220 


20 
TdC(RDYr) 
Clock 1 to READY I Delay 
510 
200 
(5) 
CL = 50 pF 
21- TdC(RDYf) - 
Clock 1 to READY 1 Delay 
390 
150 
[5)-- 


22 
TwSTB 
STROBE Pulse Width 
390 
\ 
150 
(4) 


23 
TsSTB(C) 
STROBE I to Clock 1 Setup 
Time (To Activate READY on 
Next Clock Cycle) 
560 
220 
[5) 


24 
TdIO(PD) 
lORQ I to PORT DATA Stable 
Delay (Mode 0) 
510 
200 
(5) 
25- TsPD(STB) -PORT DATA to STROBE I 


Setup Time (Mode 1) 
660 
260 


26 
TdSTB(PD) 
STROBE 1 to PORT DATA 
Stable (Mode 2) 
590 
230 
(5) 


27 
TdSTB(PDr) 
STROBE I to PORT DATA Float 
Delay (Mode 2) 
510 
200 
CL = 50 pF 


28 
TdPD(I~T) 
PORT DATA Match to INT 1 


Delay (Mode 3) 
1360 
540 


29 
TdSTB(lNT) 
STROBE I to INT I Delay 
1240 
490 


NOTES: 


[II TcC = TwCh + TwCI + TrC + TIC. 
[61 TsCS(RI) may be reduced. However, the time subtracted 
[21 Increase TdRI(DO)by 10 ns for each 50 pF increase in load 
from TsCS(Rl) will be added to TdRI(DO). 
up to 200 pF max. 
[7J 2.5 TcC > (N-2)TdIEI(IEOf) + TdMI(!EO) + TsIEI(IO) 
[3J Increase TdIO(DOl) by 10 ns for each 50 pF, increase in 
. ± TTL Buffer Delay, if any. 
loading up to 200 pF max. 
18J MI must be active for a minimum of two clock cycles to 


14J For Mode 2: TwSTB > TsPD(STB). 
reset the PI~. 
15J Increase these values by 2 ns for each 10 pF increase in 
• Timings are preliminary and subject to change. 
loading up to 100pF max. 


()()'2330{) 1 
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Zilog 


Absolute 
Maximum 
Ratings 


Test 
Conditions 


DC 
Charac- 
teristics 


Voltages on all inputs and outputs 
with respect to GND .......... .:...0.3 V to +7.0 V 


As Specified in 
Operating Ambient 
Ordering Information 
Temperature ........ in Product Specifications 
Storage Temperature ........ -65°C to + 150°C 


The characteristics below apply for the 
following test conditions, unless otherwise 
noted. All voltages are referenced to GND 
(0 V). Positive current flows into the refer- 
enced pin. Available operating temperature 
range is: 


EI S* = O°C to + 70°C, 


+4.75 V ~ Vee ~ +5.25 V 


'See Ordering Information section in product specifications 
for package temperature range and product number. 


Symbol 
Parameter 
Min 


VILe 
Clock Input Low Voltage 
-0.3 


VIHe 
Clock Input High Voltage 
Vee- 0.6 


VIL 
Input Low Voltage 
-0.3 


VIH 
Input High Voltage 
+2.0 


VOL 
Output Low Voltage 


VOH 
Output High Voltage 
+2.4 


ILl 
Input Leakage Current 


ILO 
3cState Output Leakage 
Current in Float 


IL(Sy)l 
SYNC Pin Leakage Current 


ICC 
Power Supply Current: 


SIO 
PIO 
CTC 


IOH02 
Darlington Drive Current 
-1.5 


Over speCified temperature and voltage range. 


l;'l"OTES: 


[1] SIO only 
[2] eTC and PIO only 


18330 Low Power 
Z80L ® eTC Counlerl 


'lrimme~ CCfir«:uniift 


AC and DC Characteristics 


Preliminary 


September 1983 


Stresses greater than those listed under Absolute Maxi- 
mum Ratings may cause permanent damage to the device. 
This is a stress rating only; operation of the device at any 
condition above those indicated in the operational sections 
of these specifications is not implied. Exposure to absolute 
maximum rating conditions for extended periods may affect 
device reliability. 


Max 
Typical 


+0.45 


Vee+ 0.3 
+0.8 
Vee 
+0.4 


±10 


±10 


+10/ -40 


30 
20 
20 
13 


20 
13 


Unit 


V 
V 
V 
V 
V 
V 
p.A 


p.A 


p.A 


rnA 
rnA 
rnA 
rnA 


+5V 


2.1K 


Condition 


10L = 2.0 rnA 
10H == -250 p.A 
VIN == 0 to Vee 


VOUT == 0.4 to Vee 
VIN == 0 to Vee 


VOH == 1.5V 
REXT == 390n 
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Z8330-1 and 
Z8330-3 
Z80L CTC 
AC 
Characteristics 


128 


READ 


WRITE 


ACK~NcJ~~;~~~ < 


CLOCK 


CSo. CS1 


CE 


-lORa 


\ 
no 


DATA 


CSo. CS1 


-CE 


lORa 


DATA 


M1 


lORa 


DATA 


lEI 


lEO 


-INT 


CLKITRGo-3 


(COUNTER 
MODE) 


CLKITRGo-3 


(TIMER 
MODE) 


ZCITOo-2 


~ 
~-0- 


~ 


I~ 
15 


I~ 


~I 
j 
-®- 


/ ~ 


r-L ~ 
L-J n01\ 


IX 
I--<D---- -<D-I 
\- 
, 
I--<D--- 
~I 


I~ 
<D-f-I 
, 
I..-®-- 
~I 


j 
"'t- 
r-------w-I 
~ 
FI 


l( 
f--0- ~I 


1 


I--<D--- 
~I 


I~ 
~I 


I-@--~I 


--®+I 


\ 


I~ 


T 
~ 
~I 
f-®---I 


J~ 
f- 


\ 
=4 
------®-- 
I--®- 
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I 
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\ 
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Z8330-1 and 
Z8330-1 
Z8330-3 


Z8330-3 
(1.0 MHz) 
(2.5 MHz) 


Z80L CTC- 
NUhlber Symbol 
Parameter 
Min 
Max 
Min 
Max 
Notest* 


AC 
TcC 
Clock Cycle Time 
1000 
400 


Characteristics 
2 
TwCH 
Clock Width (High) 
470 
170 
(Continued) 
3 
TwCl 
Clock Width (Low) 
470 
2000 
170 
2000 


4 
TfC 
Clock Fall Time 
30 
30 


5 
TrC 
Clock Rise Time 
30 
30 


6-Th 
All Hold Times 
0 
0 


7 
TsCS(C) 
CS to Clock I Setup Time 
640 
250 


8 
TsCE(C) 
CE to Clock I Setup Time 
510 
200 


9 
TsIO(C) 
IORQ l to Clock I Setup Time 
640 
250 


10 
TsRD(C) 
RD l to Clock I Setup Time 
610 
240 


11 
TdC(DO) 
Clock I to Data Out Delay 
610 
240 
[2] 


12 - 
TdC(DOz) -- Clock l to Data Out Float Delay 
590 
230 


13 
TsDI(C) 
Data In to Clock I Setup Time 
160 
60 
iN 
GO 


14 
TsMl(C) 
Ml to Clock I Setup Time 
540 
210 
~ 


15 
TdMl(IEO) 
Ml l to lEO l Delay (Interrupt 
e 
immediately preceding Ml) 
760 
300 
[3] 
toil 


16 
TdIO(DOI) 
IORQ l to Data Out Delay 
860 
340 
[2] 
n 


(INTA Cycle) 


17 - 
TdlEI(IEOf) - 
lEI l to lEO l Delay 
490 
190--[3]-- 


18 
TdIEI(IEOr) 
lEI I to lEO I Delay 
(After ED Decode) 
560 
220 
[3] 


19 
TdC(INT) 
Clock I to INT l Delay 
«(1) +510) 
«(1) +200) 
[4] 


20 
TdCLK(INT) 
CLK/TRG I to INT l 


tsCTR(C) satisfied 
«(19) + (26)) 
«(19) + (26)) 
[5] 
tsCTR(C) not satisfied 
«(1) + (19) + (26)) «(1) + (19) + (26)) 
[5] 


21 - 
TcCTR --- CLK/TRG Cycle Time 
2TcC --- 2TcC 
[5]-~ 


22 
TrCTR 
CLK/TRG Rise Time 
50 
50 


23 
TfCTR 
CLK/TRG Fall Time 
50 
50 


24 
TwCTRl 
CLK/TRG Width (Low) 
510 
200 


25 
TwCTRh 
CLK(TRG Width (High) 
510 
200 


26-TsCTR(Cs)--CLK/TRG I to Clock I Setup 


Time for Immediate Count 
760 
300 
[5] 


27 
TsCTR(Ct) 
CLK/TRG I to Clock I Setup 


Time for enabling of Prescaler 
on following clock I 
540 
210 
[4] 


28 
TdC(ZC/TOr) 
Clock I to ZC/TO I Delay 
660 
260 


29 
TdC(ZC/TOf) 
Clock l to ZC/TO l Delay 
490 
190 


NOTES: 


[I] TcC =.TwCh + TwCI + TrC + TfC. 
• RESET must be active for a minimum of 3 clock cycles. 
[2] Increase delay by 10 ns for each 50 pF increase in loadi'ng, 
t Units are nanoseconds unless otherwise specified; parenthetical 


200 pF maximum for data lines, and 100 pF for control lines. 
numbers reference the table number of a parameter, e.g., (I) 
[3] Increase delay by 2 ns for each 10 pF increase in loading, 
refers to TcC; timings are preliminary and subject to change. 


100 pF maximum. 
[4] Timer mode. 
[5] Counter mode. 


00-2331-01 
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Zilo 


Absolute 
Maximum 
Ratings 


Test 
Conditions 


DC 
Charac- 
teristics 


Voltages on all inputs and outputs 
with respect to GND .......... -0.3 V to + 7.0 V 


As Specified in 


Operating Ambient 
Ordering Information 
Temperature ........ in Product Specifications 
Storage Temperature ........ -65 DC to + 150 DC 


The characteristics below apply for the 
follOWing test conditions, unless otherwise 
noted. All voltages are referenced to GND 
(0 V). Positive current flows into the refer- 
enced pin. Available operating temperature 
range is: 


CJ S* = ODC to+ 70 DC, 


+4.75 V:5 Vee:5 +5.25 V 


• See Ordering Information section in product speCifications 
for package temperature range and product number. 


Symbol 
Parameter 
Min 


VILe 
Clock Input Low Voltage 
-0.3 


VIHe 
Clock Input High Voltage 
Vee- 0.6 


VIL 
Input Low Voltage 
-0.3 


VIH 
Input High Voltage 
+2.0 


VOL 
Output Low Voltage 


VOH 
Output High Voltage 
+2.4 


III 
Input Leakage Current 


IW 
3-State Output Leakage 
Current in Float 


IL(Sy)1 
SYNC Pin Leakage Current 


ICC 
Power Supply Current: 


SIO 
PIO 
CTC 


IOHD2 
Darlington Drive Current 
-1.5 


Over speCified temperature and voltage range. 


NOTES: 


[IJ SIO only 
[2J eTC and PIa only 


Z8340 Low Power 
ZaGL ® SIO Serial 
lInpun II {bun ~pUl11 


AC and! DC Characteristics 


Preliminary 


September 1983 


Stresses greater than those listed under Absolute Maxi- 


mum Ratings may cause permanent damage to the device. 
This is a stress rating only; operation of the device at any 
condition above those indicated in the operational sections 
of these specifications is not implied. Exposure to absolute 
maximum rating conditions for extended periods may affect 
device reliability. 


, Max 
Typical 


+0.45 
Vee+ 0.3 
+0.8 
Vee 
+0.4 


±10 


±10 


+10/ -40 


30 
20 
20 
13 


20 
13 


Unit 


V 
V 
V 
V 
V 
V 
p.A 


p.A 


p.A 


rnA 
rnA 
rnA 
rnA 


+5V 


2.1K 


Condition 


IOL = 2.0 rnA 
IOH = -250 p.A 
VIN = 0 to Vee 


VOUT = 0.4 to Vee 
VIN = 0 to Vee 


VOH = 1.5V 
REXT = 390n 
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Z8340-1 and 
Z8340-3 
Z80L SIO 
AC 
Characteristics 
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CLK 


CE, C/D, B/A 


lORa, liD 


lEI 


lEO 


Z8340-1 and 
Z8340-1 
Z8340-3 


Z8340-3 
(1.0 MHz) 
(2.5 MHz) 


Z80L SIO 
Number Symbol 
Parameter 
Min 
Max 
Min 
Max Notest 


AC 
TcC 
Clock Cycle Time 
1000 
4000 
400 
4000 


Characteristics 
2 
TwCh 
Clock Width (High) 
470 
2000 
170 
2000 


( Continued) 
3 
TIC 
Clock Fall Time 
30 
30 


4 
TrC 
Clock Rise Time 
30 
30 


5 
TwC1 
Clock Width (Low) 
470 
2000 
170 
2000 


6 
TsAD(C) 
CE, C/D, B/A to Clock I Setup Time 
410 
160 


7-TsCS(C)-- IORQ I RD to Clock I Setup Time 
610 
240 


8 
TdC(DO) 
Clock I to Data Out Delay 
610 
240 


9 
TsDI(C) 
Data In to Clock I Setup (Write or M1 Cycle) 
140 
50 


10 
TdRD(DOz) 
RD I to Data Out Float Delay 
590 
230 


11 
TdIO(DOI) 
IORQ I to Data Out Delay (INTACK Cycle) 
860 
340 


12 
TsMl(C) 
M1 to Clock t Setup Time 
540 
210 
13 
TsIEI(IO) 
lEI to IORQ I Setup Time (INTACK Cycle) 
510 
200 
N 
14-TdMl(IEO)--Ml I to IEO I Delay (interrupt before M1) 
760 
300 
00 


15 
TdIEI(IEOr) 
IEI t to lEO t Delay (after ED decode) 
380 
150 
f3 


16 
T dIEI(IEOf) 
IEI I to IEO I Delay 
380 
150 
e 


17 
TdC(INT) 
Clock I to INT I Delay 
510 
200 
0 


18 
TdIO(W/RWf) IORQ I or CE I to W/RDY I Delay Wait 
Mode) 
760 
300 


19 
TdC(W/RR) 
Clock t to W/RDY I Dela.y (Ready Mode) 
310 
120 
20 
TdC(W/RWz) 
Clock I to W/RDY Float Delay (Wait Mode) 
390 
150 


21 
Th 
Any unspecified Hold when Setup is specified 
0 
0 


t Units are nanoseconds unless otherwise specified; 
timings are preliminary and subject to change. 


133 


Z8340-1 and 
Z8340-3 
zeOL SIO 
AC 
Characteristics 
(Continued) 


TxO 


RxO 


W/ROY 


® 


Z8340-1 


(1.0 MHz) 
Number Symbol 
Parameter 
Min 
Max 


TwPh 
Pulse Width (High) 
500 


2 
TwPl 
Pulse Width (Low) 
500 


3 
TcTxC 
TxC Cycle Time 
1000 
00 


4 
TwTxCl 
TxC Width (Low) , 
460 
00 


5 
TwTxCh 
TxC Width (High) 
460 
00 


6-TdTxC(TxD)-TxC I _to TxD Delay (xl Mode) 
1000 


7 
T dTxC(W IRRf) TxC I to W IRDY I Delay (Ready Mode) 
5 
9 
8 
TdTxC(INT) 
TxC I to INT I Delay 
5 
9 
9 
TcRxC 
RxC Cycle Time 
1000 
00 


10 
TwRxCl 
RxC Width (Low) 
460 
00 


11 
TwRxCh 
RxC Width (High) 
460 
00 


12-TsRxD(RxC)-RxD to RxC t Setup Time (xl Mode)-- 0 
13 
ThRxD(RxC) 
RxC t to RxD Hold Time (xl Mode) 
360 


14 
TdRxC(W/RRf) RxC t to W IRDY I Delay (Ready 
Mode) 
10 
15 
TdRxC(INT) 
RxC t to INT I Delay 
10 
16 
TdRxC(SYNC) RxC t to SYNC I Delay (Output 
Modes) 
4 
17 
TsSYNC(RxC) SYNC I to RxC t Setup (External Sync 


Modes) 
100 


In all modes, the System Clock rate must be at least five times 
the maximum data rate. 


• System Clock 


13 
13 


7 


Z8340-3 
(2.5 MHz) 
Min 
Max 
Notest 


200 
200 
400 
00 


180 
00 


180 
00 


400 


5 
9 
Clk Periods· 


5 
9 
Clk Periods· 
400 
00 


180 
00 


180 
00 


0 
140 


10 
13 
Clk Periods· 


10 
13 
Clk Periods· 


4 
7 
Clk Periods· 


100 


RESE'f must be active a minimum of one complete Clock Cycle. 
t Units are nanoseconds unless otherwise specified; 
timings are preliminary and subject to change. 


134 
00·2332-01 


: : 


~~li©~ 


Pioneering the 
Microworld 


September 1983 


~i!-.;.'''':~_:;'';'''' ..._. ___ -....-__ 
'''_' ___ 
~_.;....-_"=::_"--."--.---... --.' .. -.. -".~===---"'-:----=-.... _r==-==.=~=-~===--=-.-.-.. -~----:--:J 


, A Complete Solution. Contino 


uing the family concept so suc- 
cessfully introduced by its 8-bit 
Z80 CPU, Zilog devised the 
Z8000 Family of 16-bit parts. As 
you would expect from Zilog, this 
family provides much more than 
an extension of 8-bit architecture: 
the Z8000 Family lets you design 
advanced concepts from the 
mainframe and minicomputer 
worlds into microcomputer 
systems. 
And because the Z8000 Family 


was built around a unifying set of 
protocols and interconnections, 
present and future family 
members are entirely compatible. 
Your system can grow as your 
applications mature or expand. A 
whole range of functions have 
been planned for from the begin- 
ning; the growing family now in- 
cludes parts to provide memory 
management, DMA transfer, and 
extended processing. 


System Flexibility. Even the 
smallest Z8000 systems offer 
high throughput and easy pro- 
gramming far superior to any ex- 
isting microprocessor alternative. 
In mid-range applications, Z8000 
components offer very powerful 
solutions to the design problems 
of word processing, intelligent ter- 
minals, data communications, in- 
strumentation, and process con- 
trol. In a complex network of 
multiple processors, smart 
peripheral components, and a 
distributed memory configuration, 


the Z8000 Family provides perfor- 
mance and versatility exceeding 
that of much larger-and far 
more expensive-minicomputers. 


Higher Throughput, Reduced 
Cost. The powerful instruction 
set, high execution speed, regular 
architecture, and numerous 
special featu res of the Z8000 
microprocessors dramatically in- 
crease system throughput. In- 
telligent Z8000 peripheral con- 
trollers and extended processing 
units unburden the CPU and 
boost throughput even further. 


Simply put, the Z8000 Family 


offers mme for less money. The 
Z8000 microprocessors give mid- 
range minicomputer performance 
at microprocessor cost. At com- 
ponent prices, Z8000 peripheral 
controllers perform complex 
system functions that 'previously 
required an entire PC board. 
The Z8000 Family is designed 
for multiple-processor opera- 
tion-an economical way of 
greatly increasing system perfor- 
mance. Many special features for 
multiple Z8000 CPUs facilitate the 
design of multiple-processor 
systems that share access to a 
common memory. The Memory 
Management Units can 
dynamically relocate code and 
protect memory areas. The 
Z8090/4 Z-UPC Universal 
Peripheral Controller, a complete 
slave microcomputer, and the 
Z8070 Floating Point Emulation 
Package for high-speed 
arithmetic, can manipulate data 
off-line. Asynchronous parts of 


multiple-processor systems can 
be joined by the Z8038 Z-FIO 
FIFO Interface Unit. 


An Unmatched CPU. The Z8000 
microprocessor is not just a wider 
data path, more registers, more 
data types, more addressing 
modes, more instructions and 
more addressing space. It brings 
big-machine concepts to the level 
of components. Its general- 
register architecture avoids 
bottlenecks associated with 
dedicated or implied registers. 
Special featu res support parallel 
processors, operating systems, 
compilers, and the implementa- 
tion of virtual memory. 
The Z8000 CPU is also a very 
fast machine. Its throughput is 
greater than that of any other 
16-bit microprocessor with com- 
parable clock speeds. And the 
Z8000 CPU is available with 
speeds ranging from a moderate 
4 MHz clock rate that allows you 
the choice of slow-access, low- 
cost memories to a high-speed 10 
MHz clock rate for high- 
performance systems. From the 
four versions of the Z8000 micro- 
processors, you can select the 
one best suited to your needs: the 
Z8001 for large memory applica- 
tions, the Z8002 for small 
memory applications, the Z8003 
for virtual memory, or the Z8004 
for multiprocessors sharing a 
common, small memory. 
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How to Manage Your Memory 
Better. Trends are increasingly 
toward systems with multiple 
users, complex programs, secur- 
ity requirements and memories 
that don't stop growing. These 
design problems pose questions 
not sufficiently answered by other 
microprocessor families. 
Exemplifying the Z-Family com- 


mitment to advanced architec- 
ture, the Z8010 Memory Manage- 
ment Unit (Z-MMU) and the 
Z8015 Paged Virtual Memory 
Management Unit (Z-PMMU) both 
provide flexibility in code seg- 
menter page relocation and 
sophistication in memory protec- 
tion rarely found in the 
microprocessor world. These 
devices encourage modular soft- 
ware development-a critical fac- 
tor as programs reach new levels 
of complexity. 


You are free from specifying 
where information is actually 
located in physical memory 
because the Z-MMU and Z-PMMU 
make software addresses totally 
independent from the actual 
physical memory address. While 
some microprocessor CPUs do 
have internal CPU relocation 
registers, they are dedicated and 
support few segments. These 
CPUs also restrict memory pro- 
tection. Not true for the Z-MMU 
or Z-PMMU. Various configura- 
tions of these devices can ran- 
domly relocate all 128 segments 
output by the Z8000 CPU in any 
of its available memory systems. 
For even more sophisticated 
memory management, the Z8000 
microprocessors include a new - 
member that supports virtual 
memory via an instruction abort 
mechanism. The Z8003 Virtual 
Memory Processing Unit 
(Z-VMPU) can implement either 
segmented virtual memory that 
allows demand swapping of 
segments, or a paged virtual 
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memory in which the unit of 
memory allocation is a page 
within a segment. 
But the memory management 
units are more than relocation 
·devices. They offer you a host of 
memory protection features that 
allow the system to protect its 
software from unwanted uses and 
users. Segments or pages can be 
specified as read-only to protect 
them from being overwritten, as 
system-only to protect the 
operating system from inadver- 
tent user access, as execute-only, 
and so on. A write warning zone 
is especially useful in stack 
operations so the operating 
system can deal with growing 
stacks. 


Peripheral Problem 
Solvers. Z8000 peripheral com- 
ponents are not dumb 1/0 cir- 
cuits. They perform intelligent, 
complicated tasks on their own. 
They unburden the CPU, reduce 
bus traffic, and increase system 
throughput. Complex system 
tasks that previously required 
burdensome conglomerations of 
MSI can now be handled off-line 
by Z-BUS peripherals with little 
CPU overhead. Multifunction 
Z-BUS peripherals are extensively 
programmable, so each can be 
precisely tailored to its applica- 
tion. 
Counting, timing, and parallel 
1/0 problems seem less tiresome 
with the Z8036 Z-CIO Counter 
and Parallel 1/0 device. It has 
three 16-bit counterltimers, and 
three 1/0 ports. It can even dou- 
ble as a programmable interrupt- 
priority controller. Data com- 
munications are neatly handled' 
by the Z8030 Z-SCC Serial Com- 
, 


munication Controller and the 
Z8033 Z-ASCC Asynchronous 
Serial Communications Controller, 
dual-channel multi-protocol com- 
ponents that support between 
them all popular communications 


formats. Direct memory access is 
amply supported by the Z8016 
Z-OTC DMA Transfer Controller, a 
fast dual-channel device that 
enhances the addressing power 
of the Z8000 CPU in stand-alone 
or parallel-processor environ- 
ments. General-purpose control 
and data-manipulation problems 
are smoothly solved by the Z8034 
Z-UPC Universal Peripheral Con- 
troller, a complete off-line 
microcomputer-on-a-chip with 
three 1/0 ports. This processor 
executes the same friendly, 
capable instruction set as our Z8 
Microcomputer. Bits and pieces 
of asynchronous parallel- 
processing systems are intercon- 
nected by the Z8038 Z-FIO FIFO 
InputlOutput, a surprisingly flex- 
ible device that can interface any 
major microprocessor and most 
peripherals to the Z-BUS. Its 
buffer depth can be expanded 
without limit using the 
Z8060 Z-FIFO. 


Where high-speed error detec- 


tion and correction are essential, 
the Z8065 Burst Error Processor 
(Z-BEP) offers a choice of four 
selectable industry-standard 
polynomials and three corrections 
algorithms .. It is effective for data 
rates of up to 20M bits per sec- 
ond. If encryption or decryption of 
data is necessary, the Z8068 
Data Ciphering Processor (Z-DCP) 
supports three standard ciphering 
options and key parity check. It 
can also input, output, and en- 
cipher simultaneously. To perform 
high-speed arithmetic now, the 
Z8070 Floating Point Emulation 
Package (with IEEE P754 Stan- 
dard format) can be implemented 
with any Z8000 microprocessor. 
Later this software package will 
be replaceable by the Z8070 
Floating Point Arithmetic Pro- 
cessing Unit Itself. 


Features 


General 
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[J Regular, easy-to-use architecture 


[J Instruction set more powerful than many 
minicomputers 


[J Directly addresses 8M bytes 


[J Eight user-selectable addressing modes 


[J Seven data types that range from bits to 
32-bit long words and byte and word strings 


[J System and Normal operating modes 


[J Separate code, data and stack spaces 


[J Sophisticated interrupt structure 


The Z8000 is an advanced high-e~d 16-bit 
microprocessor that spans a wide variety of ap- 
plications ranging from simple stand-alone 
computers to complex parallel-processing 
systems. Essentially a monolithic minicomputer 
central processing unit, the Z8000 CPU is 
characterized by an instruction set more 
powerful than many minicomputers; abundant. 
resources in registers, data types, addressing 
modes and addressing range; and a regular 
architecture that enhances throughouput by 
avoiding critical bottlenecks such as implied or 
dedicated registers. 


CPU resources include sixteen 16-bit 
general-purpose registers, seven data types 
that range from bits to 32-bit long words and 
byte and word strings, and eight user- 
selectable addressing modes. The 110 distinct 
instruction types can be combined with the 
various data types and addressing modes to 
form a powerful set of 414 instructions. 
Moreover, the instruction set is regular; most 
instructions can use any of the five main ad- 
dressing modes and can operate on byte, word 
and long-word data types. 
The CPU can operate in either the system or 
normal modes. The distinction between these 
two modes permits privileged operations, 
thereby improving operating system organiza- 
tion and implementation. Multiprogramming is 
supported by the "atomic" Test and Set in- 
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[J Resource-sharing capabilities for multi- 
processing systems 


[J Multi-programming support 


[J Compiler support 


D Memory management and protection provid- 
ed by Z8010 Memory Management Unit 


[J 32-bit operations, including signed multiply 
and divide 


D Z-BUS compatible 
o 4, 6 and 10 MHz clock rate 


struction; multiprocessing by a combination of 
instruction and hardware features; and com- 
pilers by multiple stacks, special instructions 
and addressing modes. 
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Figure 1. ZaDOO CPU Pin Functions 
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General 
Description 
(Continued) 


Register 
Organization 


Stacks 
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The 28000 CPU is offered in two versions: 
the 28001 48-pin segmented CPU and the 
28002 40-pin non-segmented CPU. The main 
difference between the two is in addressing 
range. The 28001 can directly address 8 mega- 
bytes of memory; the 28002 directly addresses 
64 kilobytes. The two operating modes-system 
and normal-and the distinction between code, 
data and stack spc;lces within each mode allows 
memory extension up to 48 megabytes for the 
28001 and 384 kilobytes for the 28002. 


To meet the requirements of complex, 
memory-intensive applications, a companion 


The 28000 CPU is a register-oriented 
machine that offers sixteen 16-bit general- 
purpose registers and a set of special system 
registers. All general-purpose registers can be 
used as accumulators and all but one as index 
registers or memory pointers. 
Register flexibility is created by grouping 
and overlapping multiple registers (Figures 2 
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Figure 2. Z8001 General-Purpose Registers 


The 28001 and 28002 can use stacks located 
anywhere in memory. Call and Return instruc- 
tions as well as interrupts and trqps use im- 
plied stacks. The· distinction between normal 
and system stacks separates system information 
from the application program information. Two 
stack pointers are available: the system stack 
pointer and the normal stack pointer. Because 
they are part of the general-pu:pose register 


memory-management device is offered for the 
28001. The 28010 Memory Management Unit 
manages the large address space by providing 
features such as segment relocation and 
memory protection. The 28001 can be used 
with or without the 28010. If used by itself, the 
28001 still provides an 8 megabyte direct 
addressing range, extendable to 48 megabytes. 
The 28001, 28002 and 28010 are fabricated 
with high-density, high-performance scaled 
n-channel silicon-gate depletion-load tech- 
nology, and are housed in dual in-line 
packages. 


and 3). For byte operations, the first eight 
16-bit registers (RO ... R7) are treated as sixteen 
8-bit registers (RLO, RHO, ... , RL7, RH7). The 
sixteen 16-bit registers are grouped in pairs 
(RRO ... RRl4) to form 32-bit long-word 
registers. Similarly, the register set is grouped 
in quadruples (RQO ... RQI2) to form 64-bit 
registers. 
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Figure 3. Z8002 General-Purpose Registers 


group, the user can manipulate the stack 
pointers with any instruction available for 
register operations. 
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In the 28001, register pair RR 14 is the 
implied stack pointer. Register R14 contains 
the 7-bit segment number and R15 contains the 
16-bit offset. In the 28002, register R15 is the 
implied 16-bit stack pointer. 
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The 28000 CPU contains a counter that can 
be used to automatically refresh dynamic 
memory. The refresh counter register consists 
of a 9-bit row counter, a 6-bit rate counter and 
an enable bit (Figure 4). The 9-bit row counter 
can address up to 256 rows and is incremented 
by two each time the rate counter reaches end- 
of-count. The rate counter determines the time 
between successive refreshes. It consists of a 
programmable 6-bit modulo-n prescaler 


This group of status registers contains the 
program counter, flags and control bits. When 
an interrupt or trap occurs, the entire group is 
saved and a new program status group is 
loaded. 
Figure 5 illustrates how the program status 
groups of the 28001 and 28002 differ. In the 
non-segmented 28002, the program status 
group consists of two words: the program 
counter (PC), and the flag and control word 
(FCW). In the segmented 28001, the program 
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28001 Program Status Registers 
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(n = 1 to 64), driven at one-fourth the CPU 
clock rate. The refresh period can be program- 
med by 1 to 64 p.s with a 4 MHz clock. Refresh 
can be disabled by programming the refresh 
enable/disable bit. 
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Figure 4. Refresh Counter 


status group consists of four words: a two-word 
program counter, the flag and control word, 
and an unused word reserved for future use. 
Seven bits of the first PC word designate one 
of the 128 memory segments. The second word 
supplies the 16-bit offset that designates a 
" 


memory location within the segment. 
With the exception of the segment enable bit 
in the 28001 program status group, the flags 
and control bits are the same for both CPUs. 
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Figure 5. zaooo CPU Special Registers 


The 28000 provides a very flexible and 
powerful interrupt and trap structure. Inter- 
rupts are external asynchronous events requir- 
ing CPU attention, and are generally triggered 
by peripherals needing service. Traps are syn- 
chronous events resulting from the execution 
of certain instructions. Both are processes in a 
similar manner by the CPU. 


The CPU supports three types of interrupts 
(non-maskable, vectored and non-vectored) 
and four traps (system call, Extended Process 
Architecture instruction, privileged instruc- 
tions and segmentation trap). The vectored 
and non-vectored interrupts are maskable. Of 
the four traps, the only external one is the 
segmentation trap, which is generated by the 
28010. 


The remaining traps occur when instructions 
limited to the system mode are used in the nor- 
mal mode, or as a result of the System Call in- 
struction, or for an EPA instruction. The 


descending order of priority for traps and in-" 
terrupts is: internal traps, non-maskable inter- 
rupt, segmentation trap, vectored interrupt 
and non-vectored interrupt. 
When an interrupt or trap occurs, the cur- 
rent program status is automatically pushed on 
the system stack. The program status consists 
of the processor status (PC and FCW) plus a 
16-bit identifier. The identifier contains the 
reason or source of the trap or interrupt. For 
internal traps, the identifier is the first word of 
the trapped instruction. For external traps or 
interrupts, the identifier is the vector on the 
data bus read by the CPU during the 
interrupt-acknowledge or trap-acknowledge 
cycle. 
After saving the current program status, the 
new program status is automatically loaded 
from the program status area in system 
memory. This area is designated by the pro- 
gram status area pointer (PSAP). 
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28000 instructions can operate on bits, BCD 


digits (4 bits), bytes (8 bits), words (16 bits), 
long words (32 bits) and byte strings and word 
strings (up to 64 kilobytes long), and word str- 
ings (up to 64 kilobytes long). Bits can be set, 
reset and tested; digits are used in BCD 
arithmetic operations; bytes are used for 
characters or small integer values; words are 
used for integer values, instructions and non- 
segmented addresses; long words are used for 


High-level languages, sophisticated operat- 


ing systems, large programs and data bases, 
and decreasing memory prices are all ac- 
celeratingthe trend toward larger memory re- 
quirements in microcomputer systems. The 
28001 meets this requirement with an eight 


A segmented addressing space - compared 
with linear addressing - is closer to the way a 
programmer uses memory because each pro- 
cedure and data space resides in its own seg- 
ment. The 8 megabytes of 28001 addressing 
space is divided into 128 relocatable segments 
up to 64 kilobytes each. A 23-bit segmented 
address uses a 7-bit segment address to point 
to the segment, and a 16-bit offset to address 
any location relative to the beginning of the 
segment. The two parts of the segmented ad- 
dress may be manipulated separately. The 
segmented 28001 can run any code written for 
the non-segmented 28002 in anyone of its 128 
segments, provided it is set to the non- 
segmented mode. 


The addresses manipulated by the program- 


mer, used by instructions and output by the 
28001 are called logical addresses. The, 
Memory Management Unit tkes the logical 
addresses and transforms them into the 
physical addresses required for accessing the 
memory (Figure 6). This address transforma- 
tion process is called relocation. Segment 
relocation makes user software addresses inde- 
pendent of the physical memory so the user is 
freed from specifying where information is 
actually located in the physical memory. 
The relocation process is transparent to user 
software. A translation table in the Memory 
Management Unit associates the 7-bit segment 
number with the base address of the physical 
memory segment. The 16-bit offset is added to 
the physical base address to obtain the actual 
physical address. The system may dynamically 
reload translation tables as tasks are created, 
suspended or changed. 
In addition to supporting dynamiC segment 
relocation, the Memory Management Unit also 
provides segment protection and other seg- 
ment management features. The protection 
features prevent illegal uses of segments, such 
as writing into a write-protected zone. 
Each Memory Management Unit stores 64 
segment entries that consist of the segment 


long integer values and segmented addresses. 
All data elements except strings can reside 
either in registers or memory. Strings are 
stored in memory only. 
The basic data element is the byte. The 
number of bytes us~d when manipulating a 
data element is either implied by the operation 
or - for strings and multiple register opera- 
tions - explicitly specified in the' instruction. 


megabyte addressing space. This large address 
space is directly accessed by the CPU using a 
segmented addressing scheme and can be 
managed by the 28010 Memory Management 
Unit. 


In hardware, segmented addresses are con- 


tained in a register pair or long-word memory 
location. The segment number and offset can 
be manipulated separately or together by all 
the available word and long-word operations. 
When contained in an instruction, a 
segmented address has two different represen- 
tations: long offset and short offset. The long 
offset occupies two words, whereas the short 
offset requires only one and combines in one 
word the 7-bit segment number with an 8-bit 
offset (range 0-256). The short offset mode 
allows very dense encoding of addresses and 
minimizes the need for long addresses re- 
quired by direct accessing of this large ad- 
dress space. 


base address, its attributes, size and status. 
Segments are variable in size from 256 bytes to 
64 kilobytes in increments of 256 bytes. Pairs 
of Management Units support the 128 segment 
numbers available for each of the six CPU 
address spaces. Within an address space, 
several Management Units can be used to 
create multiple translation tables. 
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Figure 6. Logical-to~Physical Address 
Transformation 
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The 2ilog Extended Processing Architecture 


(EPA) provides an extremely flexible and 
modular approach to expanding both the hard- 
ware and software capabilities of the 28000 
CPU. Features of the EPA include: 


IJ SpeCialized instructions for external proc- 
essors or software traps may be added to 
CPU instruction set. 


&1 Increases throughput of the system by using 
up to four speCialized external processors in 
parallel with the CPU. 


[] Permits modular design of 28000-based 
systems. 


IJ Provides easy management of multiple 
microprocessor configurations via "single 
instruction stream" communication. 


I IJ Simple interconnection between extended 
processing units and 28000 CPU requires no 
additional external supporting logic. 


[J Supports debugging of suspect hardware 
against proven software. 


C Standard feature on all 2ilog 28000 CPUs .. 


Specific benefits include: 


[J EPU s can be added· as the system grows and 
as EPU s with specialized functions are 
developed. 


t:l Control of EPUs is accomplished via a 


"single instruction stream" in the 28000 
CPU, eliminating many significant system 
software and bus contention management 
obstacles that occur in other multiprocessor 
(e.g., master-slave) organization schemes. 


The processing power of the 2ilog 28000 


16-bit microprocessor can be boosted beyond 
its intrinsic capability by Extended Processing 


Architectur~. Simply stated, EPA allows the 


28000 CPU to accommodate up to four Extend- 
ed Processing Units (EPUs), which perform 
speCialized functions in parallel with the CPU's 
main instruction execution stream. 
The. use of extended processors to boost the 
main CPU's performance capability has been 
proven with large mainframe computers and 
minicomputers. In these systems, speCialized 
functions such as array processing, special 
inpuVoutput processing, and data communica- 
tions processing are typically assigned to 
extended processor hardware. These extended 
processors are complex computers in their own 
right. 
The 2ilog Extended Processing Architecture 
combines the best concepts of these proven 
performance boosters with the latest in high- 
density MOS integrated-circuit design. The 
result is an elegant expansion of design 
capability-a powerful microprocessor 
architecture capable of connecting single-chip 
EPUs that permits very effective parallel 
processing and makes for a smoothly inte- 
grated instruction stream from the 28000 pro- 
grammer's point of view. A typical addition to 
the current 28000 instruction set might be 
Floating Point Instructions. 
The Extended Processing U ni ts connect 
directly to the 28000 BUS (2-BUS) and con- 
tinuously monitor the CPU instruction stream. 
When an extended instruction is detected, the 
appropriate EPU responds, obtaining or 
placing data or status information on the 
2-BUS using the 28000-generated control 
signals and performing its function as directed. 
The 28000 CPU is responsible for instructing 
the EPU and delivering operands and data to 
it. The EPU recognizes instructions intended 
for it and executes them, using data supplied 
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Figure 7. Typical Extended Processor Configuration 
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with the instruction and/or data within its inter- 
nal registers. There are four classes of EPU 
instru ctions: 


• Data transfers between main memory and 


EPU registers 


• Data transfers between CPU registers and 


EPU registers 


• EPU internal operations 


• Status transfers between the EPUs and the 


Z8000 CPU Flag and Control Word register' 
(FCW) 


Four Z8000 addressing modes may be utilized 
with transfers between EPU registers and the 
CPU and main memory: 


• Register 
• Indirect Register 


• Direct Address 


• Indexed 
In addition to the hardware-implemented , 


capabilities of the Extended Processing 
Architecture, there is an extended instruction 
trap mechanism to permit software simulation 
of EPU functions. A control bit in the Z8000 
FCW register indicates whether actual EPUs 
are present or not. If not, when an extended 
instruction is detected, the Z8000 traps on the 
instruction, so that a software "trap handler" 
can emulate the desired EPU function-a very 
useful development tool. The EPA software 
trap routine supports the debugging of suspect 
hardware against proven software. This feature 
will increase in significance as designers 
become familiar with the EPA capability of the 


Z8000 CPU. 


This software trap mechanism facilitates the 
design of systems for later addition of EPUs: 
initially, the extended function is executed as a 
trap subroutine; when the EPU is finally 
attached, the trap subroutine is eliminated and 
the EPA control bit is set. Application software 
is unaware of the change. 
Extended Processing Architecture also offers 
protection against extended instruction over- 
lapping. Each EPU connects to the Z8000 CPU 
via the STOP line so that if an EPU is 
requested to perform a second extended 
instruction function before it has completed the 
previous one, it can put the CPU into the 
Stop/Refresh state until execution of the 
previous extended instruction is complete. 


EPA and CPU instruction execution are 
shown in Figure 8. The CPU begins operation 
by fetching an instruction and determining 
whether it is a CPU or an EPU command. The 
EPU meanwhile monitors the Z-BUS for its own 
instructions. If the CPU encounters an EPU 
command, it checks to see whether an EPU is 
present; if not, the EPU may be simulated by 
an EPU instruction trap software routine; if an 
EPU is present, the necessary data and/or 
'address is placed on the Z-BUS. If the EPU is 
free when the instruction and data for it 
appear, the extended instruction is executed. 
If the EPU is still processing a previous 
instruction, it activates the CPU's STOP line to 
lock the CPU off at the Z-BUS until execution 
is complete. After the instruction is finished, 
the EPU deactivates the STOP line and CPU 
transactions continue. 


'~ 


'" -EPU') 


,---------------, 
I 
I 
I 
I 
I 
I 
&. 
L _______________ ~ 


&. DATA OR ADDRESSES ARE PLACED ON THE BUS AND USED BY THE EPU IN THE EXECUTION OF AN INSTRUCTION, 


Figure a. EPA and zaooo CPU Instruction Execution 


2007-002 


Addressing 
Modes 


2045-0285 


The information included in 28000 instruc- 
tions consists of the function to be performed, 
the type and size of data elements to be 
manipulated and the location of the data 
elements. Locations are designated by register 
addresses, memory addresses or I/O 
addresses. The addressing mode of a given 
instruction defines the address space it refer- 
ences and the method used to compute the 
address itself. Addressing modes are explicitly 
speCified or implied by the instruction. 


Figure 4 illustrates the eight addressing 
modes: Register (R), Immediate OM), Indirect 
Register OR), Direct Address (DA), Indexed 
(X), Relative Address (RA), Base Address (BA) 
and Base Indexed (BX). In general, an ad- 
dressing mode explicitly specifies either 
register address space or memory address 
space. Program memory address space and 
I/O addrE;'!ss space are usually implied by the 
instruction. 


Mode 
Operand Addressing 
Operand Value 


Register 


Immediate 


Indirect 
Register 


Direct 
Address 


Index 


Relative 
Address 


Base 
Address 


Base 
hldex 


In the Instruction 
In a Register 
In Memory 


I REGISTER ADDRESS H 
OPERAND 1 


1 OPERAND 


1 
REG.ISTER ADDRESS H 
ADDRESS t--------OI'~11 OPERAND 1 


I ADDRESS ~--------------I'-tl OPERAND 


DISPLACEMENT 


REGISTER ADDRESS 


DISPLACEMENT 


PC VALUE I--r 
""'----=--.0---1 OPERAND 


Figure 9. Addressing Modes 


The content of the 
register 


In the instruction 


The content of the location 
w hose address is in the 
register. 


The content of the location 
whose address is in the 
instruction 


The content of the location 
whose address is the 
address in the instruction. 
offset by the content of 
the register 


The content of the location 
whose address is the 
content of the program 
count or • offset by the 
displacement in the 
instruction 


The content of the location 
whose address is the 
address in the register. 
offset by the displacement 
in the instruction 


The content of the location 
whose address is the 
address in the register. 
offset by the displace- 
ment in the register 
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Input/ 
Output 


Multi-Micro- 
Processor 
Support 


Instruction. 
Set 
Summary 


Load 
and 
Exchange 
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A set of I/O instructions performs 8-bit or 
16-bit transfers betwen the CPU and I/O 
devices. I/O devices are addressed with a 
16-bi t I/O port address. The I/O port address 
is similar to a memory address; however, I/O 
address space need not be part of the memory 
address space. I/O port and memory addresses 
coexist on the same bus lines and they are 
distinguished by the status outputs. 


Multi-microprocessor systems are supported 
in hardware and software. A pair of CPU pins 
is used in conjunction with certain instructions 
to coordinate multiple microprocessors. The 
Multi-Micro Out pin issues a request for the 
resource, while the Multi-Micro In pin is used 
to recognize the state of the resource. Thus, 
any CPU in a multiple microprocessor system 
can exclude all other asynchronous CPUs from 
a critical shared resource. 


The 28000 provides the following types of 
instructions: 


[] Load and Exchange 


[] Arithmetic 


IJ Logical 


[] Program Control 


Two types of I/O instructions are available: 
standard and special. Each has its own address 
space. The I/O instructions include a compre- 
hensive set of In, Out and Block I/O instruc- 
tions for both bytes and words. Special I/O in- 
structions are used for loading and unloading 
the Memory Management Unit. The status in- 
formation distinguishes between standard and 
special I/O references. 


Multi-microprocessor systems are supported 
in software by the instructions Multi-Micro Re- 
quest, Test Multi-Micro In, Set Multi-Micro 
Out and Reset Multi-Micro Out. In addition, 
the eight megabyte CPU address space is 
beneficial in multiple microprocessor systems 
that have large memory requirements. 


t:J Bit Manipulation 


Cl Rotate and Shift 


[l Block Transfer and String Manipulation 


D Input/Output 


[] CPU Control 


Clock Cycles'- 


Mnemonics 


CLR 
CLRB 


EX 
EXB 


LO 
LOB 
LOL 


LO 
LOB 
LOL 


LO 
LOB 


Operands 


dst 


R.src 


R, src 


dst,R 


dst, 1M 


Addr. 
Modes 


R 
IR 
DA 
X 


R 
IR 
DA 
X 


R 
1M 
1M 
1R 
DA 
X 
BA 
BX 


IR 
DA 
X 
BA 
BX 


IR 
DA 
X 


Word. Byte 
Long Word 


N5 
55 
5L 
N5 
55 
5L 


7 
8 
11 
12 
14 
12 
12 
15 


6 
12 . 
15 
16 
18 
16 
16 
19 


3 
5 
7 
11 
5 (byte only) 
7 
11 
9 
10 
12 
12 
13 
15 
10 
10 
13 
13 
13 
16 
14 
17 
14 
17 


8 
II 
11 
12 
14 
14 . 15 
17 
12 
12 
15 
15 
15 
18 
14 
17 
14 
17 


11 
14 
15 
17 
15 
15 
18 


* NS = Non-Segmented SS = Segmented Short Offset SL = Segmented Long Offset 


Operation 


Clear' 
dst - a 


Exchange 
R - 
src 


Load into Register 
R - 
src 


Load into Memory (Store) 
dst - 
R 


Load Immediato into Memory 
dst - 
1M 


Load and 
Clock Cycles 
EJcchange 
Mnemonics 
Operands 
Addr. 
Word. By to 
Long Word 
Operation 
(Continued) 
Modes 
N5 
55 
8L 
N5 
55 
5L 


LDA 
R. src 
DA 
12 
13 
15 
Load Address 
X 
13 
13 
16 
R - 
source address 
BA 
15 
BX 
15 


LOAR 
R. src 
RA 
15 
Load Address Relative 
R - 
source address 


LOK 
R, src 
1M 
5 
Load Constant 
R - 
n (n = 0 ... 15) 


LOM 
R, src, n 
IR 
11 


;7 } 
Load Multiple 
DA 
14 
15 
+3n 
R - 
src (n consecutive words) 
X 
15 
15 
18 
(n = 1 .. , 16) 


LOM 
dst,R,n 
IR 
11 
Load Multiple (Store Multiple) 
00 


;7 } 
eo 
DA 
14 
15 
+3n 
dst - 
R (n consecutive words) 
C') 


X 
15 
15 
18 
(n = 1 .. , 16) 
0 
lid - 
LOR 
R, src 
RA 
14 
17 
Load Relative 
N 
n 
LORB 
R - 
src 
'G 
LORL 
(range -32768 ... + 32767) 
eJ 


LOR 
dst,R 
RA 
14 
17 
LoadRelative (Store Relative) 


LORB 
dst - 
R 


LORL 
(range -32768 ... +32767) 


POP 
dst.1R 
R 
8 
12 
Pop 
POPL 
1R 
12 
19 
dst - 
IR 
DA 
16 
16 
18 
23 
23 
25 
Autoincrement contents of R 
X 
16 
16 
19 
23 
23 
26 


PUSH 
IR, src 
R 
9 
12 
Push 
PUSHL 
1M 
12 
Autodecrement contents of R 


1R 
13 
20 
IR - 
src 
DA 
14 
14 
16 
21 
21 
23 
X 
14 
14 
17 
21 
21 
24 


Arithmetic 
AOC 
R, src 
R 
5 
Add with Carry 
ADCB 
R - 
R + src + carry 


AOO 
R, src 
R 
4 
8 
Add 
ADDB 
1M 
7 
14 
R - 
R + src 
ADDL 
IR 
7 
14 
DA 
9 
10 
12 
15 
16 
18 
X 
10 
10 
13 
16 
16 
19 


CP 
R, src 
R 
4 
8 
Compare with Register 


CPB 
1M 
7 
14 
R - src 


CPL 
IR 
7 
14 
DA 
9 
10 
12 
15 
16 
18 
X 
10 
10 
13 
16 
16 
19 


CP 
dst, 1M 
IR 
11 
Compare with Immediato 


CPB 
DA 
14 
15 
17 
dst - 1M 


X 
15 
15 
18 


DAB 
dst 
R 
5 
Docimal Adjust 


DEC 
dst,n 
R 
4 
Decrement by n 


OECB 
IR 
11 
dst - 
dst - n 
DA 
13 
14 
16 
(n = 1 ... 16) 
X 
14 
14 
17 
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Arithmetic 
Clock Cycles 
(Continued) 
Mnemonics 
Operands 
Addr. 
Word. Byte 
Long Word 
Operation 
Modes 
NS 
55 
SL 
NS 
55 
SL 


DlV 
R,src 
R 
107 
744 - 
Divide (signed) 


DlVL 
1M 
107 
744 - 
Word: Rn+ 1 - 
Rn, n+ 1 + src 
IR 
107 107 107 
744 744 744 
Rn - 
remainder 
DA 
108 109 111 
745 746 748 
Long Word: Rn+2.n+3 - 
Rn ... n+3 + src 


X 
109 109 112 
746 746 749 
Rn, n + 1 - 
remainder 


EXTS 
dst 
R 
11 
11 
Extend Sign 
EXTSB 
Extend sign of low order half of dst 


EXTSL 
through high order half of dst 


INC 
dst.n 
R 
4 
Increment by n 
INCB 
lR 
11 
dst -- dst + n 
DA 
13 
14 
16 
(n = 1 ... 16) 


X 
14 
14 
17 


MULT 
R, src 
R 
70 
282* - 
Multiply (signed) 


MULTL 
1M 
70 
282* - 
Word: Rn,n+ 1 -- Rn+ 1 • src 
IR 
70 
282* - 
Long Word: Rn ... n+ 3 --:-.Rn+2. n+3 
DA 
71 
72 
74 
283* 284* 286* 
* Plus seven cycles for each 1 in the 


X 
72 
72 
75 
284 * 284* 287* 
multiplicand 


NEG 
dst 
R 
7 
Negate 
NEGB 
IR 
12 
dst -- 0 - dst 
DA 
15 
16 
18 


X 
16 
16 
19 


SBC 
R, src 
R 
5 
Subtract with Carry 


SBCB 
R - 
R - src - carry 


SUB 
R. src 
R 
4 
8 
Subtract 


SUBB 
1M 
7 
14 
R -- R - src 


SUBL 
IR 
7 
14 
DA 
9 
10 
12 
15 
16 
18 


X 
10 
10 
13 
16 
16 
19 


Logical 
AND 
R, src 
R 
4 
AND 
ANDB 
1M 
7 
R -- RAND src 
lR 
7 
DA 
9 
10 
12 


X 
10 
10 
13 


COM 
dst 
R 
7 
Complement 


COMB 
lR 
12 
dst -- NOT dst 
DA 
15 
16 
18 


X 
16 
16 
19 


OR 
R, src 
R 
4 
OR 
ORB 
1M 
7 
R - 
R OR src 
IR 
7 
DA 
9 
10 
12 


X 
10 
10 
13 


TCC 
cc,dst 
R 
5 
Test Condition Code 
TCCB 
Set LSB if cc is true 


TEST 
dst 
R 
7 
13 
Test 


TESTB 
IR 
8 
13 
dst OR 0 
TESTL 
DA- 
11 
12 
14 
16 
17 
19 


X 
12 
12 
15 
17 
17 
20 


XOR 
R, src 
R 
4 
Exclusive OR 
XORB 
1M 
7 
R -- R XOR src 
lR 
7 
DA 
9 
10 
12 


X 
10 
10 
13 
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Program 
Clock Cycles 
Control 
Mnemonics 
Operands 
Addr. 
Word. Byte 
Long Word 
Operation 
Modes 
NS 
SS 
SL 
NS 
SS 
SL 


CALL 
d3t 
IR 
10 
15 
Call Subroutine 
DA 
12 
18 
20 
Autodecrement SP 


X 
13 
18 
21 
@ SP - 
PC 
PC- dst 


CA1R 
dst 
RA 
10 
15 
Call Relative 
Autodecrement SP 


@ SP - 
PC 
PC - 
PC + dst (range -4094 to + 4096) 


DJNZ 
R,dst 
RA 
11 
Decrement and Jump if Non-Zero 
DBJNZ 
R - 
R - 1 
If R "* 0: PC - 
PC + dst (range -254 to 0) 


IRET'" 
13 
16 
Interrupt Return 
PS - 
@ SP 
N 
Autoincrement SP 
CO e 


JP 
. cc, dst 
IR 
10 
15 
(taken) 
Jump Conditional 


<=;) 
.... 


IR 
7 
7 
(not taken) 
If cc is true: PC - 
dst 
N 


DA 
7 
8 
10 
n 
X 
8 
8 
11 
eu 
d 


JR 
cc,dst 
RA 
6 
Jump Conditional Relative 
If cc is true: PC - 
PC + dst 
(range -256 to + 254) 


RET 
cc 
10 
13 
(taken) 
Return Conditional 
7 
7 
(not taken) 
If cc is true: PC - 
@ SP 


Autoincrement SP 


SC 
src 
1M 
33 
39 
System Call 
Autodecrement SP 
@ SP - 
old PS 
Push instruction 
PS - 
System Call PS 


Bit 
BIT 
dst,b 
R 
4 
Test Bit Static 


Manipula- 
BITB 
1R 
8 
Z flag - 
NOT dst bit specified by b 
tion 
DA 
10 
11 
13 
X 
11 
11 
14 


BIT 
dst,R 
R 
10 
Test Bit Dynamic 
BlTB 
Z flag - 
NOT dst bit specified by 
contents of R 


RES 
dst,b 
R 
4 
Reset Bit Static 
RESB 
1R 
11 
Reset dst bit specified by b 
DA 
13 
14 
16 
X 
14 
14 
17 


RES 
dst,R 
R 
10 
Reset Bit Dynamic 


RESB 
Resetdst bit speCified by contents R 


SET 
dst,b 
R 
4 
Set Bit Static 
SETB 
IR 
11 
Set dst bit specified by b 
DA 
13 
14 
16 
X 
14 
14 
17 


SET 
dst,R 
R 
10 
Set Bit Dynamic 


SETB 
Set dst bit specified by contents of R 


TSET 
dst 
R 
7 
Test and Set 
TSETB 
1R 
11 
S flag - 
MSB of dst 
DA 
14 
15 
17 
dst - 
allIs 
X 
15 
15 
18 


'Privileged instruction. Executed in system mode only. 
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Rotate 
Clock Cycles 
and 
Mnemonics 
Operands 
Addr. 
Word. Byte 
Long Word 
Operation 
Shift 
Modes 
NS 
SS 
SL 
NS 
SS 
SL 


RL 
dst.n 
R 
6forn = I 
Rotato Loft 
RLB 
R 
7 forn = 2 
by n bits (n = 1. 2) 


RLC 
dst.n 
R 
6forn = 1 
Rotate Left through Carry 
RLCB 
R 
7 forn :;: 2 
by nbits (n = 1,2) 


RLDB 
R,src 
R 
9 
Rotato Digit Left 


RR 
dst,n 
R 
6 for n = 1 
Rotate Right 
RRB 
R 
7forn = 2 
by n bits (n = 1,2) 


RRC 
dst.n 
R 
6forn= 1 
Rotate Right through Carry 
RRCB 
R 
7forn = 2 
by n bits (n = 1. 2) 


RRDB 
R,src 
R 
9 
Rotato Digit Right 


SDA 
dst,R 
R 
(IS + 3 n) 
(IS + 3 n) 
Shift Dynamic Arithmetic 


SDAB 
Shift dst left or right 


SDAL 
by contents of R 


SDL 
dst,R 
R 
(15 + 3 n) 
(15 + 3 n) 
Shift Dynamic Logical 


SDLB 
Shift dstleft or right 


SDLL 
by contents of R 


SLA 
dst,n 
R 
(13 + 3 n) 
(13 +3 n) 
Shift Left Arithmetic 


SLAB 
by n bits 


SLAL 


SLL 
dst,n 
R 
(13 + 3 n) 
(13 + 3 n) 
Shift Left Logical 


SLLB 
by n bits 


SLLL 


SRA 
dst,n 
R 
(13 + 3 n) 
(13 + 3 n) 
Shift Right Arithmetic 


SRAB 
by n bits 


SRAL 


SRL 
dst,n 
R 
(13 + 3 n) 
(13 + 3 n) 
ShUt Right Logical 


SRLB 
by n bits 


SRLL 


Block 
CPD 
Rx, src, Ry, cc 
IR 
20 
Compare and Decrement 
Transfer 
CPDB 
Rx - sre 


and String 
Aulodecrement sre address 
Manipula- 
Ry - 
Ry - 1 
tion 


CPDR 
Rx, src, Ry, ce 
IR 
(11 + 9 n) 
Compare. Decrement and Repeat 


CPDRB 
RX - sre 
Autodeerement sre address 
Ry - 
Ry - 1 
Repeat until ee is true or Ry = 0 


CPI 
RX' sre,Ry, cc 
IR 
~O 
Compare and Increment 


CPIB 
RX - src 
Autoinerement sre address 
Ry - 
Ry - 1 


CPIR 
RX' sre, Ry, ee 
·IR 
(II + 9 n) 
Compare. Increment and Repeat 


CPIRB' 
HX - src 
Autoincrement src address 
Ry - 
Ry - 1 
Repeat until ec is true or Ry = 0 


CPSD 
dst, src, H, ec 
IR 
25 
Compare String and Decrement 


CPSDB 
dst - sre 
Autodecrement dst and sre ~ddresses 
H - R-I 
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Block Transfer 
Clock Cycles 
and String 
Mnemonics 
Operands 
Addr. 
Word. Byte 
Long Word 
Operation 
Manipulation 
Modes 
NS 
SS 
SL 
NS 
SS 
SL 
(Continued) 


CPSDR 
dst, src, R, cc 
IR 
(11 + 14 n) 
Compare String. Deer. and Repeat 


CPSDRB 
dst - src 
Au todecrement dst and src addresses 
R - 
R - 1 
Repeat until cc is true or R = 0 


CPSI 
dst, src, R. cc 
IR 
25 
Compare String and Increment 


CPSIB 
dst - src 
Autoincrement dst and src addresses 
R - R-l 


CPSIR 
dst, src, R, cc 
IR 
(11 + 14 n) 
Compare String. Incr. and Repeat 


CPSIRB 
dst - src 
Autoincrement dst and src addresses 
R - 
R - 1 
Repeat until cc is true or R = 0 
00 
~ 


LDD 
dst, src, R 
IR 
20 
Load and Decrement 
e e 
LDDB 
dst - 
src 
.... 


Autodecrement dst and src addresses 
- 
N 


R - 
R - 1 
fi 
tV 


LDDR 
dst, src, R 
IR 
(11 + 9 n) 
Load. Decrement and Repeat 
el 


LDDRB 
dst - 
src 
Autodecrement dst and src addresses 
R - R-l 
Repeat until R = 0 


LDI 
dst, src, R 
IR 
20 
Load and Increment 
LDIB 
dst - 
src 
Autoincrement dst and src addresses 
R - R-l 


LDIR 
dst, src, R 
IR 
(11 + 9 n) 
Load. Increment and Repeat 
LDIRB 
dst - 
src 
Autoincrement dst and src addresses 
R - R-l 
Repeat until R = 0 


TRDB 
dst, src, R 
IR 
25 
Translate and Decrement 
dst - 
src (dst) 
Autodecrement dst address 
R - R-l 


TRDRB 
dst, src, R 
IR 
(11 + 14 n) 
Translate. Decrement and Repeat 
dst - 
src (dst) 
Autodecrement dst address 
R - R-l 
Repeat until R = 0 


TRIB 
dst, src, R 
IR 
25 
Translate and Increment 
dst - 
src (dst) 
Autoincrement dst address 
R - R-l 


TRIRB 
dst, src, R 
IR 
(11 + 14 n) 
Translate. Increment and Repeat 
dst - 
src (dst) 
Autoincrement dst address 
R - R-l 
Repeat until R = 0 


TRTDB 
src I, src2, R 
IR 
25 
Translate and Test. Decrement 
RHI - 
src 2 (src 1) 
Autodecrement src 1 address 
R - R-l 
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Block Transfer 
Clock Cycles 
and String 
Mnemonics 
Operands 
Addr. 
Word. Byte 
Long Word 
Operation 
Manipulation 
Modes 
NS 
SS 
SL 
NS 
SS 
SL 
(Continued) 


TRTDRB 
src 1, src2, R 
IR 
(11 + 14 n) 
Translate and Test. Decr. and Repeat 
RHI - 
src 2 (src 1) 
Autodecrement src 1 address 
R - 
R-l 
Repeat until R = a or RHI = a 


TRTIB 
src 1, src2, R 
IR 
25 
Translate and Test. Increment 
RHI - 
src 2 (src 1) 
Autoincrement src 1 address 
R - 
R - 1 


TRTIRB 
src 1, src2, R 
IR 
(11 + 14 n) 
Translate and Test. Incr. and Repeat 
RHI - 
src 2 (src 1) 
Autoincrement src 1 address 
R - 
R...: 1 
Repeat until R = a o~ RHl = a 


Input/ 
IN* 
R, src 
IR 
10 
Input 
Output 
INB* 
DA 
12 
R - 
src 


IND* 
dst, src, R 
IR 
21 
Input and Decrement 


INDB* 
dst - 
src 
Autodecrement dst address 
R - 
R-l 


INDR* 
dst, src, R 
IR 
(11 + 10 n) 
Input. Decrement and Repeat 


INDRB* 
dst - 
src 
Autodecrement dst address 
R - 
R - 1 
Repeat until R = a 


INI* 
dst, src, R 
IR 
21 
Input and Increment 


INIB* 
dst - 
src 
Autoincrement dst address 
R - 
R - 1 


INIR* 
dst, src, R 
IR 
(11 + 10 n) 
Input. Increment and Repeat 


INIRB* 
dst - 
src 
Autoincrement dst address 
R - R-l 
Repeat until R = a 


OUT'" 
dst,H 
IR 
10 
Output 


OUTB* 
DA 
12 
dst.- R 


OUTD* 
dst, src, R 
IR 
21 
Output and Decrement 


OUTDB* 
dst - 
src 
Autodecrement src address 
R - R-l 


OTDR* 
dst, src, R 
IR 
(11 + 10 n) 
Output. Decrement and Repeat 


OTDRB* 
dst - 
src 
Autodecrement src address 
R - R-l 
Repeat until R = a 


OUTI* 
dst, src, R 
IR 
21 
Output and Increment 


OUTIB* 
dst - 
src 
Autoincrement src address 
R - 
R - 1 


OTIW 
dst, src, R 
IR 
(11 + 10 n) 
Output. Increment and Repeat 


OTIRB* 
dst - 
src 
Autoincrement src address 
R - 
R - 1 
Repeat until R = a 


'Privileged instructions. Executed in system mode only. 
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Input/Output 
Clock Cycles 
(Continued) 
Mnemonics 
Operands 
Addr. 
Word. Byte 
Long Word 
Operation 
Modes 
NS 
SS 
SL 
NS 
SS 
SL 


SIN* 
R, src 
DA 
12 
Special Input 


SINB* 
R - 
src 


SIND* 
dst, src, R 
IR 
21 
Special Input and Decrement 


SINDB* 
dst - 
src 
Autodecrement dst address 
R - 
R- 1 


SINDR* 
dst, src, R 
IR 
(11 + 10 n) 
Special Input. Decrement and Repeat 
SINDRB* 
dst - 
src 
Autodecrement dst address 
R - 
R - 1 
Repeat until R = 0 


SINI* 
dst, src, R 
IR 
21 
Special Input and Increment 


SINIB* 
dst - 
src 
N 


Autoincrement dst address 
CO 


R - R-l 
0 e 
tool 
SINIR* 
dst,src,R 
IR 
(11 + 10 n) 
Special Input. Increment and Repeat 
N 


SINIRB* 
dst - 
src 
n 


Autoincrement dst address 
IV 


R - R-l 
c:= 


Repeat until R = 0 


SOUT* 
dst, src 
DA 
12 
Special Output 


SOUTB* 
dst - 
src 


SOUTD* 
dst, src, R 
IR 
21 
Special Output and Decroment 


SOUTDB* 
dst - 
src 
Autodecrement src address 
R - R-l 


SOTDR* 
dst, src, R 
IR 
(11 + 10 n) 
Special Output. Decr. and Repeat 


SOTDRB* 
dst - 
src 
Autodecrement src address 
R - R-l 
Repeat until R = 0 


SOUTI* 
dst, src, R 
IR 
21 
Special Output and Increment 


SOUTIB* 
dst - 
src 
Autoincrement src address 
R - R-l 


SOTIR* 
dst, src, R 
R 
(11 + 10 n) 
Special Output. Incr. and Repeat 


SOTIRB* 
dst - 
src 
Autoincrement src address 
R - 
R - 1 
Repeat until R = 0 


CPU 
COMFLG 
flags 
7 
Complement Flag 
Control 
(Any combination of C, Z, s, PIV) 


01* 
int 
7 
Disable Interrupt 
(Any combination of NVI, VI) 


EI* 
int 
7 
Enable Interrupt 
(Any combination of NVI, VI) 


HALT* 
(8 + 3 n) 
HALT 


LDCTL* 
CTLR,src 
R 
7 
Load into Control Register 
CTLR - 
src 


LDCTL* 
dst,CTLR 
R 
7 
Load from Control Register 
dst - 
CTLR 


'Privileged instructions. Executed in system mode only. 
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CPU 
Control 
(Continued) 


Condition 
Codes 


Status 
Code 
Lines 
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Clock Cycles 


Mnemonics 
Operands 


LDCTLB 
FLGR,src 


LDCTLB 
dst,FLGR 


LDPS* 
src 


MlII,(* 


MREQ* 
dst 


MRES* 


MSET* 


NOP 


RESFLG 
flag 


SETFLG 
flag 


Addr. 
Modes 


R 


R 


IR 
DA 
X 


R 


Word. Byte 


NS 
SS 
SL 


7 


7 


12 
16 
16 
20 
22 
17 
20 
23 


7 


(12 + 7 n) 


5 


5 


7 


7 


7 


• Privileged instructions. Executed in system mode only. 


Code 
Meaning 


Always false 
Always true 


Z 
Zero 
NZ 
Not zero 
C 
Carry 
NC 
No Carry 


PL 
Plus 


MI 
Minus 
NE 
Not equal 
EQ 
Equal 


OV 
Overflow 


NOV 
No overflow 


PE 
Parity is even 


PO 
Parity is odd 
GE 
Greater than or equal (signed) 
LT 
Less than (signed) 
GT 
Greater than (signed) 
LE 
Less than or equal (signed) 


UGE 
Unsigned greater than or equal 


ULT 
Unsigned less than 


UGT 
Unsigned greater than 


ULE 
Unsigned less than or equal 


Long Word 


NS 
SS 
SL 


Flag Settings 


Z = 1 
Z = 0 
C = 1 
C=O 
S = a 
S = 1 
Z = 0 
Z = 1 
PIV = 1 
PIV = 0 
PIV = 1 
PIV = 0 


Operation 


Load into Flag Byte Register 
FLGR - 
src 


Load from Flag Byte Register 
dst - 
FLGR 


Load Program Status 
PS - 
src 


Test Multi-Micro Bit 
Set S if Mj is Low; reset S if Mi is High. 


Multi-Micro Request 


Multi-Micro Reset 


Multi-Micro Set 


No Operation 


Reset Flag 
(Any combination of C, Z, S, PIV) 


Set Flag 
(Any combination of C, Z, S, PIV) 


CC Field 


0000 
1000 
0110 
1110 
0111 
1111 
1101 
OlGl 
1110 
0110 
0100 
1100 
0100 
1100 
(S XOR PI'l) = 0 
1001 
(S XOR PIV) = 1 
0001 
[Z OR (S XOR PIV)l = 0 
1010 
[Z OR (S XOR PIV)l = 1 
0010 
C=O 
1111 
C = 1 
0111 


[(C = 0) AND (Z = 0)1 = 1 
1011 


(C OR Z) = 1 
0011 


Note that some condition codes have identical flag settings and binary fields in the instruction: 
Z = EQ, NZ = NE, C = ULT, NC = UGE, OV = PE, NOV = PO 


ST3-STO 
Definition 
ST3-STO 
Definition 


0000 
Internal operation 
100 a 
Data memory request 
000 1 
Memory refresh 
1001 
Stack memory request 
0010 
1/0 reference 
1010 
Data memory request (EPU) 
001 1 
Special 1/0 reference (e.g., to an MMU) 
101 1 
Stack memory request (EPU) 
0100 
Segment trap acknowledge 
1 100 
Program reference, nth word 


0101 
Non-maskable interrupt acknowledge 
1 101 
Instruction fetch, first word 


0110 
Non-vectored interrupt acknowledge 
1 1 10 
Extension processor transfer 


01 1 1 
Vectored interrupt acknowledge 
1 1 1 1 
Reserved 


Pin 
Description 
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ADo-ADlS. Address/Data (inputs/outputs, 
active High, 3-state). These multiplexed 
address and data lines are used both for I/O 
and to address memory. 


AS. Address Strobe (output, active Low, 
3-state). The rising edge of AS indicates 
addresses are valid. 


BUSACK. Bus Acknowledge (output, active 
Low). A Low on this line indicates the CPU has 
relinquished control of the bus. 


BUSREQ. Bus Request (input, active Low). 
This line must be driven Low to request the 
bus from the CPU. 


B/W. Byte/Word (output, Low = Word, 
3-state). This signal defines the type of memory 
reference on the 16-bit address/data bus. 


CLK. System Clock (input). CLK is a 5V 
single-phase time-base input. 


DS. Data Strobe (output, active Low, 3-state). 
This line times the data in and out of the CPU. 


MREQ. Memory Request (output,. active Low, 
3-state). A Low on this line indicates that the 
address/data bus holds a memory address. 


MI. Mo. Multi-Micro In, Multi-Micro Out 
(input and output, active Low). These two lines 
form a resource-request daisy chain that allows 
one CPU in a multi-microprocessor system to 
access a shared resource. 


NMI. Non~Maskable Interrupt (edge triggered, 
input, active Low). Ahigh-to-low transition on 
NMI requests a non-maskable interrupt. The 


ADo 
48 
ADs 


ADg 
47 
SNs 


AD10 
46 
SN5 


AD11 
45 
AD7 


AD12 
44 
ADs 


AD13 
43 
AD4 


STOP 
42 
SN4 


MI 
41 
AD5 


AD15 
40 
AD3 


AD14 
10 
39 
AD2 


+5V 
11 
38 
AD1 


Vi 
12 
37 
SN2 
ZOOO1 
NVI 
13 
36 
GND 


SEGT 
14 
35 
CLOCK 


NMI 
15 
34 
AS 


RESET 
16 
33 
RESERVED 


Mo 
17 
32 
BiVi 


MREQ 
18 
31 
N/S 
os 
19 
30 
R/W 


ST3 
20 
29 
BUSACK 


ST2 
21 
28 
WAIT 


ST1 
22 
27 
BUSREQ 


STo 
23 
26 
SNo 


SN3 
24 
25 
SN1 


Figure 10. Z8001 Pin Assignments 


NMI interrupt has the highest priority of the 
three types of interrupts. 


N/S. Normal/System Mode (output, Low = 
System Mode, 3-state). Nis indicates the CPU 
is in the normal or system mode. 


NVI. Non- Vectored Interrupt (input, active 
Low). A Low on this line requests a non- 
vectored interrupt. 


RESET. Reset (input, active Low). A Low on 
this line resets the CPU. 


R/W. Read/Write (output, Low = Write, 
3-state). R/W indicates that the CPU is reading 
from or writing to memory or I/O. 


SEGT. Segment Trap (input, active Low). The 
Memory Management Unit interrupts the CPU 
with a Low on this line when the MMU detects 
a segmentation trap. Input on Z8001 only. 


SNo-SNs. Segment Number (outputs, active 
High, 3-state). These lines provide the 7-bit 
segment number used to address one of 128 
segments by the Z80 1 0 Memory Management 
Unit. Output by the Z8001 only. 


STo-STa. Status (outputs, active High, 3-state). 
These lines specify the CPU status (see table). 


STOP. Stop (input, active Low). This input can 
be used to single-step instruction execution. 


VI. Vectored Interrupt (input, activ~ Low). A 
Low on this line requests a vectored interrupt. 


WAIT. Wait (input, active Low). This line 
indicates to the CPU that the memory or I/O 
device is not ready for data transfer. 


Reserved. Do not connect. 


ADg 
ADo 


AD10 
ADs 


AD11 
AD7 


AD12 
ADs 


AD13 
AD4 


STOP 
AD5 


MI 
AD3 


AD15 
AD2 


AD14 
AD1 


+5V 
10 
31 
GND 


Vi 
Z8002 


11 
CLOCK 


NVI 
12 
AS 


NMI 
13 
28 
RESERVED 


RESET 
14 
27 
Bm 


Mo 
15 
26 
N/S 


MREQ 
16 
25 
Rm 
os 
17 
24 
BUSACK 


ST3 
18 
23 
WAif 


ST2 
19 
22 
BUSREQ 


ST1 
20 
21 
STo 


Figure 11. Z8002 Pin Assignments 
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The Z8000 CPU executes instructions by 
stepping through sequences of basic machine 
cycles, such as memory read or write, 1/0 
device read or write, interrupt acknowledge, 
and internal execution. Each of these basic 
cycles requires three to ten clock cycles to 
execute. Instructions that require more clock 
cycles to execute are broken up into several 
machine cycles. Thus no machine cycle is 
longer than ten clock cycles and fast response 
to a Bus Request is guaranteed. 
The instruction opcode is fetched by a 
normal memory read operation. A memory 
refresh cycle can be inserted just after the 
completion of any first instruction fetch (IFl) 
cycle and can also be inserted while the 
following instructions are being executed: 
MULT, MULTL, DIV, DIVL, HALT, all Shift 


Memory read and instruc~ion fetch cycles 
are identical, except for the status information 
on the STo-ST3 outputs. During a memory 


T, 
-I- 
.. 


T, 


instructions, all Block Move instructions, and 
the Multi-Micro Request instruction (MREQ). 
The following timing diagrams show the 
relative timing relationships of all CPU signals 
during each of the basic operations. When a 
machine cycle requires additional clock cycles 
for CPU internal operation, one to five clock 
cycles are added. Memory and I/O read and 
write, as well as interrupt acknowledge cycles, 
can be extended by activating the WAIT input. 
For exad timing information, refer to the com- 
posite timing diagram. 


Note that the WAIT input is not synchronized 
in the Z8000 and that the setup and hold times 
for WAIT relative to the clock must be met. If 
asynchronous WAIT signals are generated, 
they must be synchronized with the CPU clock 
before entering the Z8000" 


read cycle, a 16-bit address is placed on the 
ADo-ADl5 outputs early in the first clock 
period, as shown in Figure 12. (In the Z8001, 


T, 
- - 
- 


CLOCt( 
I ~ 


l 
- 


\'/AIT 


_INSERTS WAIT STATE 


STATlISI!r. 
(BIW. NIS. 


STo-ST,) 


SlIo-ml6 
SEGMENT NUMBER 


-AS 


MRcQ 


( 
') 


AD 
MEMORY ADDRE!;S '>--- 
DATA IN 
READ 
I' 


-05 


READ 


niw 
/ 
~ 


READ 


AD 
MEMORY ADDRESS 
DATA OUT 
WRITE 


os 
WRITE 
r 
R1W 
\ 
WRITE 


Figuro 12. Momory Read and Writo Timing 
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the 7-bit segment number is output on 
SNo-SN6 one clock period earlier than the 
16-bit address offset to compensate for the 
delay in the memory management circuitry.) 
A valid address is indicated by the rising 
edge of Address Strobe. Status and mode 
information become valid early in the memory 
access cycle and remain stable throughout. 
The state of the WAIT input is sampled in the 
middle of the second clock cycle by the falling 
edge of Clock. If WAIT is Low, an additional 
clock period is added between T2 and T3. 
WAIT is sampled again in the middle of this 


I/O timing is similar to memory read/write 
timing, except that one wait state is automat- 
ically inserted between T2 and T3 (Figure 13). 


T, 
T2 


CLOCK 
I 
-I 
- 


WAIT 


- =x 


STATUSES 
(BNi, STo-ST3) 
, 
- 


HIS 


-rLJ 
is 


MREQ 


-ex 


AD 
PORT ADDRESS 
~)------- 
INPUT - 


i 


os 
INPUT 


RlW LI 


INPUT - 


- ex 


AD 
PORT ADDRESS 
OUTPUT - 


os 
OUTPUT 


-" 


R/W 
OUTPUT 


wait cycle, and additional wait states can be 
inserted. This allows interfacing slow 
memories. No control outputs change during 
wait states. 
Although Z8000 memory is word organized, 
memory is addressed as bytes. All instructions 
are word-aligned, using even addresses. 
Within a 16-bit word, the most significant byte 
(Ds-DI5) is addressed by the low-order address 
(Ao = Low), and the least significant byte 
(Do-D7) is addressed by the high-order 
address <Ao = High). 


Both the segmented Z8001 and the non- 
segmented Z8002 use 16-bit I/O addresses. 


TWA 
T3 


If> 
1 


~ 


XQS 
...... INSERT WAIT STATE 


LOW 


HIGH 


( DATA IN > C 


"- 


DATA OUT 


~ 


Figure 13. Input/Output Timing 


157 


Interrupt and 
Segment 
Trap Request 
and 
Acknow ledge 


The 28000 CPU recognizes three interrupt 
inputs (non-maskable, vectored and non- 
vectored) and a segmentation trap input. Any 
High-to-Low transition on the NMI input is 
asynchronously edge detected and sets the 
internal NMI latch. The VI, NVI and 
SEGT inputs as well as the state of the internal 
NMI latch are sampled at the beginning of T3 
in the last machine cycle of any instruction. 
In response to an interrupt or trap, the sub- 
sequent IFr cycle is exercised, but ignored. 
The internal state of the CPU is not altered and 
the instruction will be refetched and executed 
after the return from the interrupt routine. The 
program counter is not updated, but and the 
system stack pointer is decremented in 
preparation for pushing starting information 
onto the system stack. 
The next machine cycle is the interrupt 


acknowledge cycle. This cycle has five 
automatic wait states, with additional wait 
states possible, as shown in Figure 14. 
After the last wait state, the CPU reads the 
information on ADo-AD15 and stores it tem- 
porarily, to be saved on the stack later in the 
acknowledge sequence. This word identifies 
the source of the interrupt or trap. For the 
non-vectored and non-maskable interrupts, all 
16 bits can represent peripheral device status 
information. For the vectored interrupt, the 
low byte is the jump vector, and the high byte 
can be extra user status. For the segmentation 
trap, the high byte is the Memory Management 
U nit identifier and the low byte is undefined. 
After the acknowledge cycle, the N/S output 
indicates the automatic change to system 
mode. 


1 
CYClEOFANY~"-- 
FETCHIF1 
....------------ 
-----------~. 
SAVING 
INSTRUCTION 
(ABORTED) 
AUTOMATIC .!AIT STATES 
I 


LAST MACHINE 
I 
INSTRUCTIONj 
ACKNCOyWCLLEEDGE 
I 
STATUS 


CLOCK rtJ-LJiJ ru= .... T, 
T, 


Vi, iiVi, SEaT 


INTERNAL 
NMl 


Status 
Saving 
Sequence 


Bus Request 
Aclmowledge 
Timing 
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R/W 


ofw 


STo-ST3 


~--~~------------------------- 


( 
,IDENTIFIER 
) 
'--___ 
--J 


Figure 14. Interrupt and Segment Trap Request/ Acknowlodge Timing 


The machine cycles following the interrupt 
acknowledge or segmentation trap acknowl- 
edge cycle push the old status information on 
the system stack (Figure 12) in the following 
order: the 16-bit program counter; the 7-bit 
segment number (28001 only); the flag control 


A Low on the BUSREQ input indicates to the 


CPU that another device is requesting the 
Address/Data and Control buses. The asyn- 
chronous BUSREQ input is synchronized at the 
beginning of any machine cycle (Figure 15). If 


word; and finally the interrupt/trap identifier. 
Subsequent machine cycles fetch the new pro- 
gram status from the program status area, and 
then branch to the interrupt/trap service 
routine. 


BUSREQ is Low, an internal synchronous 
BUSREQ signal is generated, which-after com- 
pletion of the current machine cycle-causes 
the BUSACK output to go Low and all bus out- 
puts to go into the high-impedance state. The 


2045-0290 


Bus Request! 
Aclmow ledge 
(Continued) 


Stop 


2045-0291, 0292 


requesting device-typically a DMA-can then 
control the bus. 
When BUSREQ is released, it is synchron- 
ized with the rising clock edge and the 


BUSACK output goes High one clock period 
later, indicating that the CPU will again take 
control of the bus. 


_---BUS AVAILABLE-_ 


iiUSREQ 
--~------------~----+---~~ 


INTERNAL 
SUSRE-a 


~-- ---- --- ---- 


~-- ---- ---- --- 
________________ 
~J 


>--- 


MREQ.~,----------------~~ 
5To- 5T 31 
)--- 
---- 
---- 
--- 
B/W, Riw, HIS ________________ ~J 


Figure 15. Bus Request/Acknowledge Timing 


The STOP input is sampled by the last falling 
clock edge immediately preceeding any IFl 
cycle (Figure 16) and before the second word 
of an EPA instruction is fetched. If STOP is 
found Low between the IF 1 cycle, a stream of 
memory refresh cycles is inserted after T3, 
again sampling the STOP input on each falling 
clock edge in the middle of the,T3 states. Dur- 
ing the EPA instruction, both EPA instruction 
, words are fetched but any data transfer or 


subsequent instruction fetch is postponed' until 
STOP is sampled High. This refresh operation 
does not use the refresh p~escaler or its divide- 
by-four clock prescaler; rather, it double- 
increments the refresh counter every three 
clock cycles. When STOP is found High again, 
the next refresh cycle is completed, any 
remaining T states of the IFl cycle are then 
executed and the CPU continues its operation. 


1-----'F,--_'1 


T, 
T, 
T3 I' 
T" 
R~::ESH~I 
~REF;,:SH-----:-1 
T. 
T, 


CLOCK 


STOP\~! 
_____ 
~\~/ ____ DC 
J\~ ____________ _ 


v 


\~---I/ 


\ ____ --J/ 


STO-ST3 ==:>< _____ 
'F_, __ 
---JX~ _______ _ 
MEMORY REFRESH 
\~ 
___________________ 
~A 
___ _ 


/ 
_______ L 


ruW 


Figuro 16. Stop Timing 
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Certain extended instructions, such as 
Multiply and Divide, and some special instruc- 
tions need additional time for the execution of 
internal operations. In these cases, the CPU 
goes through a sequence of internal operation 
machine cycles, each of which is three to eight 


T, 


B/W 


T, 


clock cycles long (Figure 17). This allows fast 
response to Bus Request and Refresh Request, 
because bus request or refresh cycles can be 
inserted at the end of any internal machine 
cycle. 


T, 


UNDEFINED 


HIS 
SAME AS PREVIOUS CYCLE 


Figure 17. Internal Operation Timing 


When the 6-bit prescaler in the refresh 
counter has been decremented to zero, a 
refresh cycle consisting of three T -states is 
started as soon as possible (that is, after the 
next IF} cycle or Internal Operation cycle). 
The 9-bit refresh counter value is put on the 
low-order side of the address bus (ADo-ADa); 
ADg-ADIS are undefined (Figure 18). Since 
the memory is word-organized, Ao is always 
Low during refresh and the refresh counter is 


# 


CLOCK 


always incremented by two, thus stepping 
through 256 consecutive refresh addresses on 
ADI-ADa. Unless disabled, the presettable 
prescaler runs continuously and the delay in 
starting a refresh cycle is therefore not 
cumulative: 
While the STOP input is Low, a continuous 
stream of memory refresh cycles, each three 
T-states long, is executed without using the 
refresh pres caler . 


REFRESH 


AD 
REFRESH ADDRESS >------- -------- -C 


lVii. BlW. Hrs }_-+ ____ -+ __ 
S_AM_E A_S_PR_EV_'OU_St-CY_CL_E ----t---- 


FigurQ 18. Memory Refresh Timing 
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Halt 


Reset 


A HALT instruction executes an unlimited 
number of 3-cycle internal operations, 
inter-spersed with memory refresh cycles 
whenever requested. An interrupt, segmenta- 
tion trap or reset are the only exits from a 
HALT instruction. 


A Low on the RESET input causes the follow- 
ing results within five clock cycles (Figure 19): 


'm ADo-AD15 are 3-stated 


II AS, ISS, MREQ, STo-ST3, 


BUSACK and MO are forced High 


II SNo-SN6 are forced Low 


CI Refresh is disabled 


&I R/W, B/W and Nis are not affected 


When RESET has been High for three clock 
periods, two consecutive memory read cycles 


\~------------- 


-------~>----- 


u 


l 


/ 


----------------~ 


MREQ __________________________ -J/ 


~ ____________________________ _J/ 


STo-ST3 ________________________ -J/ 


BiVi 


BUSACK 
/ 


-------~ 


Mo _______________________ -J/ 


The CPU samples the VI, NVI, NMI and 
SEGT inputs at the beginning of every T3 
cycle. If an input is found active during two 
consecutive samples, the subsequent IF 1 cycle 
is exercised, but ignored, and the normal 
interrupt acknowledge cycle is started. 


are executed in the system mode. In the 28001, 
the first cycle reads the flag and control word 
from location 0002, the next reads the 7-bit 
program counter segment number from loca- 
tion 0004, the next reads the 16-bit PC offset 
from location 0006, and the followingIFl cycle 
starts the program. In the 28002, the first cycle 
reads the flag and control word from location 
0002, the next reads the PC from location 
0004, and the following IFI cycle starts the 
program. 


EX, 
EX, 


IF, 


Figuro 19. Rosot Timing 
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Z8001/Z8002 
Z8001AlZ8002A Z800lBIZ8002Bt 


Numbor 
Symbol 
Paramotor 
Min 
Max 
Min 
Max 
Min 
Max 


1 
TcC 
Clock Cycle Time 
2S0 
2000 
16S 
·2000 
100 
2000 


2 
TwCh 
Clock Width (High) 
lOS 
2000 
70 
2000 
40 


3 
TwCl 
Clock Width (Low) 
lOS 
2000 
70 
2000 
40 


4 
TfC 
Clock Fall Time 
20 
10 
10 


5--TrC 
Clock Rise Time 
20 
IS 
10- 


6 
TdC(SNv) 
Clock I to Segment Number Valid 
130 
110 
70 
(SO pF load) 
7 
TdC(SNn) 
Clock I to Segment Number Not Valid 
20 
10 
S 
8 
TdC(Bz) 
Clock I to Bus Float 
6S 
SS 
40 


9 
TdC(A) 
Clock I to Address Valid 
100 
7S 
SO 


10--TdC(Az)--- Clock I to Address Float 
6S 
SS 
40- 


11 
TdA(DR) 
Address Valid to Read Data Required Valid 
47S* 
30S* 
180* 


12 
TsDR(C) 
Read Data to Clock I Setup Time 
30 
20 
10 


13 
TdDS(A) 
DS I to Address Active 
80* 
4S* 
20* 


14 
TdC(DW) 
Clock I to Write Data Valid 
100 
7S 
SO 


15--ThDR(DS)-- Read Data to DS I Hold Time 
0 
0 
0 


16 
TdDW(DS) 
Write Data Valid to DS I Delay 
295* 
195* 
110* 


17 
TdA(MR) 
Address Valid to MREQ I Delay 
S5 
35* 
20* 
N 
18 
TdC(MR) 
Clock I to MREQ I Delay 
80 
70 
40 
00 


19 
TwMRh 
MREQ Width (High) 
210* 
135* 
80* 
e 
20 -- TdMR(A)--- MREQ I to Address Not Active 
70* 
3S* 
20* 
e .... 
21 
TdDW(DSW) 
Write Data Valid to DS I (Write) Delay 
S5* 
35* 
15* 
N 
22 
TdMR(DR) 
MREQ I to Read Data Required Valid 
375* 
230· 
140* 
n 
23 
TdC(MR) 
Clock I MR~Q I Delay 
80 
60 
45 
~ 
24 
TdC(ASf) 
Clock I to AS I Delay 
80 
60 
40 
c:: 
25 -- TdA(AS) --- Address Valid to AS I Delay 
55* 
35* 
20* 


26 
TdC(ASr) 
Clock I to AS I Delay 
90 
80 
40 


27 
TdAS(DR) 
AS I to ~ad Data Required Valid 
360* 
220* 
140* 


28 
TdDS(AS) 
DS I to AS I Delay 
70* 
35* 
15* 
29 
TwAS' 
AS Width (Low) 
85* 
55* 
30* 
30 -- T dAS(A) --- AS I to Address Not Active Delay 
70* . 
45* 
20* 


31 
TdAz(DSR) 
Address Float to DS (Read) I Delay 
0 
0 
0 


32 
TdAS(DSR) 
AS I to DS (Read) I Delay 
80* 
5S* 
30* 


33 
TdDSR(DR) 
DS (Read) I to Read Data Required Valid 
205* 
130* 
70* 


34 
TdC(DSr) 
Clock I to DS I Delay 
70 
65 
45 
35--TdDS(DW)-- DS I to Write Data Not Valid 
75* 
45* 
25* 
36 
TdA(DSR) 
Address V alid to DS (Read) I Delay 
180* 
110* 
6S* 
37 
TdC(DSR) 
Clock I to DS (Read) I Delay 
120 
85 
60 


38 
TwDSR 
DS (Read) Width (Low) 
275* 
185* 
110* 


39 
TdC(DSW) 
Clock I to DS (Write) I Delay 
95 
80 
60 


40--TwDSW--- DS (Write) Width (Low) 
18S* 
110* 
75· 


41 
TdDSI(DR) 
DS (I/O) I to Read Data Required Valid 
330* 
210* 
120* 


42 
TdC(DSf) 
Clock I to DS (I/O) I Delay 
120 
90 
60 


43 
TwDS 
DS (I/O) Width (Low) 
410* 
255* 
160* 


44 
TdAS(DSA) 
AS I to DS (Acknowledge) I Delay 
106S* 
690* 
410* 


4S--TdC(DSA)--Clock I to DS (Acknowledge) I Delay 
120 
85 
65- 
46 
TdDSA(DR) 
DS (Acknowledge) I to Read Data 
45S* 
295* 
165* 
Required Delay 
47 
TdC(S) 
Clock I to Status Valid Delay 
110 
85 
60 


48 
TdS(AS) 
Status Valid to AS I Delay 
50* 
30* 
10* 


49 
TsR(C) 
RESET to Clock I Setup Time 
180 
70 
SO 


50--ThR(C) 
RESET to Clock I Hold Time 
0 
0 
0 


51 
TwNMI 
NMI Width (Low) 
100 
70 
SO 


52 
TsNMl(C) 
NM~ 
Clock I Setup Time 
140 
70 
SO 


53 
TsVI(C) 
VI, NVI to Clock I Setup Time 
110 
SO 
40 


54 
Th Vl(C) 
VI, NVI to Clock I Hold Time 
20 
20 
10 
55--TsSGT(C)--SEGT to Clock I Setup Time 
70 
55 
40 


56 
ThSGT(C) 
SEGT to Clock I Hold Time 
0 
0 
0 


57 
TsMl(C) 
MI to Clock I Setup Time 
180 
140 
80 


58 
ThMI(C) 
MI to Clock I Hold Time 
0 
0 
0 


59 
TdC(MO) 
Clock I to MO Delay 
120 
8S 
70 
60--TsSTP(C)---STOP to Clock I Setup Time 
140 
100 
50 


61 
ThSTP(C) 
STOP to Clock I Hold Time 
0 
0 
0 


62 
TsW(C) 
WAIT to Clock I Setup Time 
SO 
30 
20 


63 
ThW(C) 
WAIT to Clock I Hold Time 
10 
10 
S 
64 
TsBRQ(C) 
BUSREQ to Clock I Setup Time 
90 
80 
60 
65-- ThBRQ(C)-- BUSREQ to Clock I Hold Time 
10 
10 
S 
66 
TdC(BAKr) 
Clock I to BUSACK I Delay 
100 
75 
60 


67 
TdC(BAKf) 
, Clock I to BUSACK I Delay 
100 
75 
60 


68 
TwA 
Address Valid Width 
lS0* 
95* 
SO* 


69 
TdDS(S) 
DS I to STATUS Not Valid 
80* 
SS* 
30* 


·Clock-cycle-time-dependent characteristics. See table on following page. 
r Units in nanoseconds (ns). All timings are preliminary: 
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Z8001/Z8002 
Z8001A/Z8002A 
Z8001B/Z8002B 


Number 
Symbol 
Equation 
Equation 
Equation 


11 
TdA(DR) 
2TeC + TwCh - 130 ns 
2TeC + TwCh - 95 ns 
2TeC + TwCh - 60 ns 
13 
TdDS(A) 
TwCl- 25 ns 
TWCl- 25 ns 
TwCl- 20 ns 
16 
TdDW(DS) 
TeC + TwCh - 60 ns 
TeC + TwCh - 40 
TeC + TwCh - 30 ns 
17 
TdA(MR) 
TwCh - 50 ns 
TwCh - 35 ns 
TwCh - 20 ns 
19--TwMRh 
TeC - 40 ns 
TeC - 30 ns 
TeC - 20 ns 


20 
TdMR(A) 
TwCl- 35 ns 
TwCl- .35 ns 
TwCl - 20 ns 


21 
TdDW(DSW) 
TwCh - 50 ns 
TwCh - 35 ns 
TwCh - 25 ns 
22 
TdMR(DR) 
2TeC - 130 ns 
2TeC - 100 ns 
2TeC - 60 ns 
25 
TdA(AS) 
TwCh - 50 ns 
TwCh - 35 ns 
TwCh - 20 ns 
27-- TdAS(DR)-- 2TeC - 140 ns 
2TeC - 110 ns 
2TeC - 60 ns 
28 
TdDS(AS) 
TwCl- 35 ns 
TwCl- 35 ns 
TwCl- 25 ns 
29 
TwAS 
TwCh - 20 ns 
TwCh - 15 ns 
TwCh - 10 ns 


30 
TdAS(A) 
TwCl- 35 ns 
TwCl- 25 ns 
TwCl - 20 ns 
32 
TdAS(DSR) 
TwCl - 25 ns 
TwCl- 15 ns 
TwCl - 10 ns 
33--TdDSR(DR)-- TeC + TwCh - 150 ns 
TeC + TwCh - 105 ns 
TeC + TwCh - 70 ns --- 
\ 
35 
TdDS(DW) 
TwCl- 30 ns 
TwCl- 25 ns 
TwCl - 15 ns 
36 
TdA(DSR) 
TeC - 70 ns 
TeC - 55 ns 
TeC - 35 ns 
38 
TwDSR 
TeC + TwCh - 80 ns 
TeC + TwCh - 50 ns 
TeC + TwCh - 30 ns 


40 
TwDSW 
TeC - 65 ns 
TeC - 55 ns 
TeC - 25 ns 
41--TdDSI(DR)-- 2TeC - 170 ns 
2TeC - 120 ns 
2TeC - 80 ns 
43 
TwDS 
2TeC - 90 ns 
2TeC - 75 ns 
2TeC - 40 ns 
44 
TdAS(DSA) 
4TeC + TwCl - 40 ns 
4TeC + TwCl - 40 ns 
4TeC + TwCl - 30 ns 
46 
TdDSA(DR) 
2TeC + TwCh - 150 ns 
2TeC + TwCh - 105 ns 
2TeC + TwCh - 75 ns 
48 
TdS(AS) 
TwCh - 55 ns 
TwCh - 40 ns 
TwCh - 30 ns 
68--TwA 
TeC - 90 ns 
TeC - 70 ns 
TeC - 50 ns 
'69 
TdDS(s) 
TwCl- 25 ns 
TwCl - 15 ns 
TwCl- 10 ns 
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Absolute 
Maximum 
Ratings 


Test 
Conditions 


DC 
Character- 
istics 


8085-0006 


Voltages on all inputs and outputs 
with respect to GND .......... -0.3 V to + 7.0 V 
Operating Ambient 
Temperature ........ See Ordering Information 
Storage Temperature ........ -65°C to + 150 °C 


The characteristics below apply for the 
following test conditions, unless otherwise 
noted. All voltages are referenced to GND 
(0 V). Positive current flows into the refer- 
enced pin. Available operating temperature 
ranges are: 
[] S* = O°C to + 70°C, 
+4.75V!5Vee !5 +5.25V 


IJ E* = - 40°C to + 85°C, 


+4.75 V !5 Vee !5 +5.25 V 


IJ M* = -55°C to + 125°C, 


+ 4.5 V !5 Vee !5 + 5.5 V 


'See Ordering Information section for package 
temperature range and product number. 


Symbol 
Parameter 


VeH 
Clock Input High Voltage 


VeL 
Clock Input Low Voltage 


VIH 
Input High Voltage 


VIH RESET 
Input High Voltage on RESET 
pin 


VIL 
Input Low Voltage 


VOH 
Output High Voltage 


VOL 
Output La';'; Voltage . 


IlL 
Input Leakage 


IlL SEGT 
Input Leakage on SEGT pin 


IOL 
Output Leakage 


ICC 
Vee Supply Current 


Min 


Vee-O.4 


-0.3 


2.0 


2.4 


-0.3 


2.4 


-100 


Stresses greater than those listed under Absolute Maxi- 
mum Ratings may cause permanent damage to the device. 
This is a stress rating only; operation of the device at any 
condition above those indicated in the operational sections 
of these specifications is not implied. Exposure to absolute 
maximum rating conditions for extended periods may affect 
device reliability. 


+5V 


2.1K 


All ac parameters assume a total load 
capacitance (including parasitic capacitances) 
of 100 pF max, except for parameter 6 (50 pF 
max). Timing references between two output 
signals assume a load difference of 50 pF max. 


Max 


Vee+ 0.3 


0.45 


Vee+ 0.3 


Vee to .3 


0.8 


0.4 


±10 


100 


±10 


300 


Unit 


V 


V 


V 


V 


V 


V 


V 


pA 


pA 


p.A 


rnA 


Condition 


Driven by External Clock 
Generator 


Driven by External Clock 
Generator 


IOH = -250 p.A 


IOL = +2.0 rnA 


0.4 :5 VIN :5 + 2.4 V 


0.4 :5 VIN :5 + 2.4 V 
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Ordering 
Product 
Package/ 
Product 
Package/ 


Information 
Number 
Temp 
Speed 
Description 
Number 
Temp 
Speed 
Description 


Z8001 
CE 
4.0 MHz 
CPU (segmented, 
Z8002 
DS 
4.0 MHz 
CPU (nonseg- 
48-pin) 
mented, 40-pin) 


Z8001 
CM 
4.0 MHz 
Same as above 
z8062 
PE 
4.0 MHz 
Same as above 


Z8001 
CMB 
4.0 MHz 
Same as above 
Z8002 
PS 
. 4.0 MHz 
Same as above 


Z8001 
CS 
4.0 MHz 
Same as above 
Z8002A 
CE 
6.0 MHz 
Same as above 


Z8001 
DE 
4.0 MHz 
Same as above 
Z8002A 
CM 
6.0 MHz 
Same as above 


Z8001 
DS 
4.0 MHz 
Same as above 
Z8002A 
CMB 
6.0 MHz 
Same as above 


Z8001 
PE 
4.0 MHz 
Same as above 
za002A 
CS 
6.0 MHz 
Same as above 


Z8001 
PS 
4.0 MHz 
Same as above 
Z8002A 
DE 
6.0 MHz 
Same as above 


Z8001A 
CE 
6.0 MHz 
Same as above 
Z8002A 
DS 
6.0 MHz 
Same as above 


Z8001A 
CS 
6.0 MHz 
Same as above 
Z8002A 
PE 
6.0 MHz 
Same as above 


Z8001A 
DE 
6.0 MHz 
Same as above 
Z8002A 
PS 
6.0 MHz 
Same as above 


Z8001A 
DS 
6.0 MHz 
Same as above 
Z8002B 
CE 
10.0 MHz 
Same as above 


Z8001A 
PE 
6.0 MHz 
Same as above 
Z8002B 
CM 
10.0 MHz 
Same as above 
. Z8001A 
PS 
6.0 MHz 
Same as above 
Z8002B 
CMB 
10.0 MHz 
Same as above 


Z8002 
CE 
4.0 MHz 
CPU (nonseg- 
Z8002B 
CS 
10.0 MHz 
Same as above 
mented, 40-pin) 
Z8002B 
DE 
10.0 MHz 
Same as above 


Z8002 
CM 
4.0 MHz 
Same as above 
Z8002B 
DS 
10.0 MHz 
Same as above 


Z8002 
CMB 
4.0 MHz 
Same as above 
Z8002B 
PE 
10.0 MHz 
Same as above 


Z8002 
CS 
4.0 MHz 
Same as above 
Z8002B 
PS 
10.0 MHz 
Same as above 


Z8002 
DE 
4.0 MHz 
Same as above 


"NOTES: C = Ceramic, D = Cerdip, P = Plastic; E = -;-40°C to +85°C, M = -55°C to + 125°C, MB = -55°C to + 125°C with 
MIL-STD-883 with Class B processing, S = O°C to + 70°C. 
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FEATURES 


IJ 
Regular, easy-to-use architecture. 


[J 
Instruction set more powerful than many minicom- 
puters. 


[J 
Direct addressing capability of up to 8M bytes in 
each address space. 


[J 
Supports 
implementation 
of 
virtual 
memory 
systems. 


D 
Eight user-selected addressing modes. 


D 
Wide range of data types including bits, bytes, 
words, 32-bit long words, and byte and word strings. 


B 
Binary-compatible with Z8001/2 CPUs. 


GENERAL DESCRIPTION 


The Virtual Memory Microprocessor Units (Z8003 and 
Z8004 Z-VMPUs) accommodate applications that range 
from the simplest to the most complex.' 


The 
Z8003 
Z-VMPU 
uses 
both 
segmented 
and 
nonsegmented address spaces. It also provides facilities 
for the implementation of demand segment swapping or 
a demand paged virtual memory system. 


The Z8004 Z-VMPU uses only nonsegmented address 
spaces. It also provides facilities for the implementation 
of a demand paged virtual memory system. 


Both Z-VMPUs interface with the entire Z8000 Family of 
support components. Used alone or with Z8000 Family 
components, the advanced architecture of these LSI 
Z-VMPUs permits the implementation of systems that 
have the flexibility and the sophisticated features usually 
associated with minicomputers or mainframe com- 
puters. 


-18003/4 Z8000™ Z·VMPU 
Virtual Memory 
ProcessIng Unil 


Product 
Specification 


September 1983 


1.1 
Separate System and Normal operating modes. 


a 
Sophisticated interrupt structure. 


El 
Resource-sharing capabilities for multiprocessing 
systems. 


c 
Multi-programming support. 


['J 
32-bit operations, including signed multiply and 
divide. 


D 
Z_BUSTM compatible. 


r.:J 
Multiple clock- rates: 4, 8, or 10 MHz. 


The Z8003/4 microprocessors are binary compatible 
with other Z8000 Family microprocessors. The features 
that distinguish these microprocessors from the Z8001 
and Z8002 microproce~sors are the abort capability and 
the Test anp Set status. 


An abort request function aids in the implementation of 
virtual memory systems. The abort function is initiated 
by memory management circuitry external to the 
Z-VMPU when an address issued by the Z-VMPU 
references information (data or instructions) that is not in 
main memory. After the abort interrupt function, a ser- 
vice routine must bring the page or segment containing 
the addressed data into main memory. The mainstream 
program is then restarted at the point of interruption. An 
abort interrupt differs from a standard interrupt in that 
the executing instruction is stopped immediately upon 
. detection of the interrupt; this prevents the loss of infor- 


mation needed for a successful restart. 
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The Test and Set instruction (TSET), in addition to its 
semaphore test and set function, causes status code 
1111 to be placed onto output lines ST o-ST 3 during the 
data read bus transaction. It can be used by external cir- 
cuitry to lock memory to prevent it from being accessed 
by any other device during the execution of the current 
TSET instruction. 


The architectural features of the Z-VMPU combine to 
produce a powerful and versatile microprocessor. These 
features result in the following benefits: 


• 
High-density code 


• 
Efficient compilation of programs 


III 
Support for typical operating system operations 


• 
Complex data structures 


• 
Large-scale virtual memory systems 


The Z-VMPU is designed so that a powerful memory 
management system can be used to improve the utiliza- 
tion of the main memory either as a standard memory or 
as a virtual memory configuration. Zilog produces 
Memory Management Units (Z-MMUs) designed for use 
with the Z8003 Z-VMPU to implement both virtual and 
nonvirtual memory systems. 


The architectural resources of the Z-VMPUs include six- 
teen 16-bit registers, seven data types (ranging from bits 
to 32-bit words, and byte and word strings), eight ad- 
dressing modes, and a powerful instruction set. 


. A general mechanism has been provided for extending 
the basic instruction set through the use of external 
devices called Extended Processing Units (EPUs). In 
general, an EPU is dedicated to performing complex and 
time-consuming tasks (such as floating-point arithmetic) 
so as to unburden the Z-VMPU. FigL!re 1 shows a 
simplified block diagram of the Z-VMPU. _ 
1--------------· 
------~ 
I 
I 
I 
I 
I 
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GENERAL 
PURPOSE 
REGISTERS 


INSTRUCTION 
EXECUTION 
CONTROL 


ARITHMETIC 
LOGIC 
UNIT 


INTERNAL DATA BUS 


PROGRAM 
STATUS 
REGISTERS 


EXCEPTION 
HANDLING 
CONTROL 


Z·BUS 
INTERFACE 


I 
L Z8000CPU 
I 
____________________ ---.J 


Figure 1. Block Diagram 


2084-001 


ARCHITECTURE 


General·Purpose Registers 


The Z-VMPU is a register-oriented machine that contains 
sixteen 16-bit general-purpose registers. All general- 
purpose registers can be used as accumulators and all 
but one can be used as index registers or. memory 
pointers. 


Register flexibility is created by grouping and overlap- 
ping multiple registers (Figure 2). For byte operations, 
the first eight 16-bit registers can be treated as sixteen 
8-bit registers. The sixteen 16-bit registers can also be 
grouped in pairs to form eight 32-bit long-word registers. 
Similarly, the register set can be grouped in quadruples 
to form four 64-bit registers. 


Stacks. Z-VMPUs can use stacks located anywhere in 
main memory. Call and Return instructions, as well as in- 
terrupts and traps, use an implied stack. Two stack 
pointers are available, the System Stack Pointer and the 
Normal Stack Pointer. The two stacks separate 
operating system (System mode) information from ap- 
plication program (Normal mode) information. The user 
can manipulate the Stack Pointer with any instruction 
available for register operations because the Stack 
Pointer is part of the general-purpose register group. 


In the Z8003 Z-VMPU, register pair RR14 is the implied 
Stack Pointer for segmented operation. Register R14 
contains the 7-bit segment number and R15 contains the 
16-bit offset. Register R15 is used as the Stack Pointer 
during nonsegmented operation. Since the Z8004 runs 
only in the nonsegmented mode, register R15 is used as 
the Stack Pointer. 


R~O { 


RO 17 
RHO 
01 7 
RLO 
o I 


Rl 
15 
RHl 
RLl 


ROO 


.RR2 { 


R2 
RH2 
RL2 


R3 
RH3 
RL3 


RR4 { 


R4 
RH4 
RL4 


R5 
RH5 
RL5 


R04 


RR6 { 


R6 
RH6 
RL6 


R7 
RH7 
RL7 


RR8 { 
R8 
15 
o I 
GENERAL 
PURPOSE 
REGISTERS 


R9 


R08 


{ 
Rl0 
RR10 
Rl1 


{ 
R12 
RR12 
R13 I 
'W 
'''". """'0'"'' "". "'., 
R012 


R14 
(NSPSEG) NORMAL STACK POINTER (SEG. NO.) 
• RR14 
R15' 
SYSTEM STACK POINTER (OFFSET) 


R1S 
(NSPOFF) NORMAL STACK POINTER (OFFSET) 


Z8003 


Special·Purpose Registers 


The Z-VMPUs also provide 16-bit special-purpose 
registers. These registers include Program Status 
registers, Program Status Area Pointer register(s), and a 
Refresh Counter. The configurations of the special- 
purpose registers for the Z8003 and Z8004 Z-VMPUs are 
shown in Figure 3. 


Program Status Registers. This group of registers con- 
sists of the Program Counter (PC) register and the Flag 
and Control Word (FCW) register. The PC register con- 
tains the address of the next instruction to be loaded into 
the CPU. The low-order byte of the FCW register con- 
tains the following flags: 


C, Carry flag, is used to indicate that a carry was made 
out of the high-order bit position of a register used as an 
accumulator. 


Z, Zero flag, is generally used to indicate that the result 
of an operation was zero. 


S, Sign flag, is generally used to indicate that the result 
of an operation was negative. 


P/V, Parity/Overflow flag, is generally used to indicate 
either even parity (after logical operations on byte 
operands) or an overflow condition (after arithmetic 
operations). 


D, Decimal·Adjust flag, is used in BCD arithmetic to in- 
dicate the type of instruction that was executed (addition 
or subtraction). 


RRO { 


RO 
RHO 
i 7 
RLO 
a I 


Rl 
RHl 
RLl 


ROO 


RR2 { 


R2 
RH2 
RL2 


R3 
RH3 
RL3 


RR4 { 


R4 
RH4 
RL4 


RS 
RHS 
RLS 


R04 


RR6 { 


R6 
RH6 
RL6 


R7 
RH7 
RL7 


RR8 { 
R8 
15 


R9 


R08 


{ 
Rl0 
RR10 
Rll 


{ 
R12 
RR12 
R13 


R012 
I '" 


RR14 
R1S' 
SYSTEM STACK POINTER (OFFSET) 


, 
R15 
NORMAL STACK POINTER (OFFSET) 


Z8004 


Figure 2. Z·VMPU General·Purpose Registers 
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H, Half Carry flag, is used to convert the binary result of 
a previous addition or subtraction into the correct 
decimal (BCD) result. 


The high-order byte of the FCW register contains control 
bits which are used to control the Z-VMPU operating 
modes and to enable various types of interrupts. The 
following control bits are contained in the FCW: 


NVIE, Nonvectored Interrupt Enable bit. This bit must 
be 1 to enable the Z-VM'PU to accept non-vectored inter- 
rupts. 


VIE, Vectored Interrupt Enable bit. This bit must be 1 
to enable the Z-VMPU to accept vectored interrupts. 


SIN, System/Normal bit. This bit indicates the current 
Z-VMPU operating mode. When 0, SIN specifies Normal 
mode; When 1, SIN specifies System mode. The Z-VMPU 
output N/S represents the complement of this bit. 


EPA, Extended Processor Architecture mode bit. 
This bit, when 1, indicates that the system contains an 
Extended Processing Unit (EPU) and extended instruc- 
tions are to be executed by the appropriate EPU. When 
0, this bit specifies that extended instructions will be 
trapped for software emulation. 


SEG, Segmentation mode bit (Z8003 only). When 1, 
this bit specifies that the Z-VMPU is in segmented ad- 
dressing mode; when 0 it specifies that the Z-VMPU is in' 
the non segmented addressing mode. 
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Figure 3. Program Status Registers 
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Program Status Area Pointer (PSAP) Register. A Pro- 
gram Status Area (PSA) array in main memory is used to 
store new program status information (i.e., sets of FCW 
and PC values). Each time an interrupt or trap occurs, 
the current program status is saved and a new program 
status is loaded into the status registers from the Pro- 
gram Status Area. The address of the table that contains 
new program status values is contained in a Program 
Status Area Pointer (PSAP) register (Figure 4). The low- 
order byte of the offset address is assumed to be all 
zeros; therefore, the Program Status Area must start on 
a 256-byte boundary. 


Refresh Register. The Z-VMPU contains a program- 
mable counter that automatically refreshes dynamic 
memory. The Refresh Counter register consists of a 9-bit 
row counter, a 6-bit rate counter, and an Enable bit 
(Figure 5). The 9-bit row counter can address up to 256 
rows and is incremented by two each time the rate 
counter reaches end-of-count. The rate counter deter- 
mines the time between successive refreshes. It con- 
sists of a programmable, 6-bit modulo-n prescaler (n = 
,1-64), driven at one-fourth the Z-VMPU clock rate. 
Refresh can be disabled by programming the refresh 
Enable/Disable bit. If this register is not needed for 
memory refresh, it can function as an on-board internal 
timer. 
. 
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Figure 4. Z8003 Program Status Area 
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SYSTEM AND NORMAL MODES 


The Z-VMPUs can run in either System or Normal mode. 
In System mode, all instructions can be executed and all 
Z-VMPU control registers can be accessed. This mode is 
useful in programs that perform operating system func- 
tions. 


In Normal mode, some instructions, such as the 1/0 in- 
structions, cannot be executed. In addition, the Z-VMPU 
control registers cannot be accessed. This mode is in- 
tended for use by application (user) programs. 


ADDRESS SPACES 


Programs and data can be located in the main memory 
of the computer system or in peripheral devices. In 
either case, the location of the information must be 
specified by an address before that information can be 
accessed. A set of these addresses is called an address 
space. 


The Z-VMPUs support two different types of addresses 
and thus two categories of address space: 


[J 
Memory addresses, which specify locations in main 
memory. 


o 
1/0 addresses, which specify the ports through 
which peripheral devices are accessed. 


Within the two general types of address spaces (memory 
and 1/0), there are several subcategories. Figure 6 
shows the address spaces that are available on both 
types of Z-VMPUs. 


The difference between the Z8003 and the Z8004 
Z-VMPUs lies not in the number and type' of address 
spaces, but rather in the organization and size of each 
space. For the Z8003, the memory address space con- 
tains 8M byte§:) of addresses grouped into 128 separate 
segments. For the Z8004, the memory space is a 
homogeneous collection of 64K_ bytes of addresses. In 
both the Z8003 and the Z8004, each 1/0 address space 
contains 32K byte port addresses and 64K word port ad- 
dresses. 


When an address is used to access data, the address 
spaces can be distinguished by the state of the status 
lines (STo-ST3) and by the value of the NormallSystem 
line (N/S). The states of the four status lines are deter- 
mined by the way the address was generated. The value 
of the NIS output line is the complement of the SIN con- 
trol bit in the FCW register. 


The 23-bit segmented addresses are divided into 7-bit 
segment identifiers (segment numbers) and 16-bit off- 
sets to address locations rerative to the beginning of the 
specified segment. In hardware, segmented addresses 
are contained in a register pair or in a long-word memory 
location. The segment number and offset of an address 
can be manipulated separately or together by all 
available word and long word operations. 
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The use of separate Z-VMPU System and Normal modes 
promotes the integrity of the system by preventing user 
programs from having access to the operating system 
and the control registers. The current operating mode is 
specified by the SIN bi,t of the FCW register. The comple- 
ment of the state of this bit is output by the Z-VMPU on 
line N/S. Output NIS can be used to separate System and 
Normal address spaces. 


In an instruction, a segmented address can have one or 
two representations; long-offset or short-offset. A long- 
offset address occupies two words, with the first word 
containing the 7-bit segment number and the second 
word containing the 16-bit offset. A short-offset address 
requires only one word, which combines the 7-bit seg- 
ment number with an 8-bit offset (range 0-256). The 
short-offset mode allows very dense encoding of ad- 
dresses and minimizes the need for long addresses to 
directly access each 8M byte address space. 


Nonsegmented addresses are 16 bits and permit access 
of up to 64K of contiguous byte locations. 


The Z8004 operates only in the nonsegmented address 
mode. The Z8003 can operate in either the segemented 
or nonsegmented address mode. When the Z8003 is in 
nonsegmented mode, all address representations 
assume implicitly the segment number contained in the 
7-bit segment number field of the PC. 


110 Addresses 


There is a set of 1/0 instructions that perform 8- or 16-bit 
transfers between a Z-VMPU and its 1/0 devices. 1/0 
devices are addressed with 16-bit 1/0 port addresses. An 
1/0 port address is similar to a memory address; 
however, the 1/0 address space is not part of the 
memory address space. Memory-mapped 1/0 can be im- 
plemented by dedicating memory locations to 1/0 device 
registers. Two types of 1/0 instruction are available: 
Standard and Special, Each type has its own address 
space. Special 1/0 instructions are used for loading and 
unloading memory management units. 


MEMORY ADDRESS SPACES 


SYSTEM MODE 
NORMAL MODE 


INSTRUCTIONS 
INSTRUCTIONS 


DATA 
DATA 


STACK 
STACK 


I/O ADDRESS SPACES 


SYSTEM MODE 


STANDARD I/O 
SPECIAL 1/0 


Figure 6. Address Spaces on,the Z8003 and Z8004 
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INSTRUCTION ADDRESSING MODES 


The information included in Z-VMPU instructions con- 
sists of the function to be performed, the type and size of 
data elements to be manipulated, and the locations of 
the data elements. Locations are designated by register 
addresses, memory addresses, or I/O addresses. The 
addressing mode of a given instruction defines the 
method used to compute the address. Addressing 
modes are explicitly specified or implied by the instruc- 
tion. Locations are designated using one of the following 
addressing modes: 


BI 
Register Mode (R). The data element is located in 
one of the 16 general-purpose registers or a control 
register. 


fI 
Immediate Mode (1M). The data element is located 
in the instruction. 


II 
Indirect Register Mode (IR). The data element can 
be found in the location whose address is given in a 
specified register. 


INSTRUCTION SET 


Major Groups 


The major groups of instructions provided by the 
Z-VMPU are described in the following paragraphs. A 
detailed summary of the instructions is presented in 
Table 3 (located at the back of this document). 


Load and Exchange. These instructions move data 
among registers or between registers and main memory. 


Arithmetic. 
These 
instructions 
perform 
integer 
arithmetic. The basic instructions (e.g., add, subtract, 
multiply and divide) in this group use standard two's 
complement binary format. Support is also provided for 
implementing BCD arithmetic. 


Logical. These instructions perform logical operations 
(i.e., AND, OR, XOR, and complementation) on the bits of 
specified operands. The operands can be bytes or 
words. The Test Long (TESTL) instruction, however, per- 
mits logical operations to be performed on 32-bit quan- 
tities. 


. Program Control. These instructions affect the Pro- 
gram Counter, thereby controlling program flow. 


Bit Manipulation. These instructions manipulate in- 
dividual bits in registers or main memory. 


Rotate and Shift. These instructions shift and rotate the 
contents of registers. 


Block Transfer and String Manipulation. These in- 
structions perform string comparisons, string transla- 
tions, and block transfer functions. 
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13 
Direct Address Mode (DA). The data element can 
be found in the location whose address is given in 
the instruction. 


Gil 
Index Mode (X). The data element can be found in 
the location whose address is the sum of the con- 
tents of an index value in a specified register and an 
address in the instruction. 


f1J 
Relative Address Mode (RA). The data element 
can be found in the location whose address is the 
sum of the contents of the Program Counter and a 
displacement given in the instruction. 


E!! 
Base Address Mode (BA).The data element can be 
found in the location whose address is the sum of a 
base address in a specified register and a displace- 
ment given in the instruction. 


Il] 
Base Index Mode (BX). The data element can be 
found in the location whose address is the sum of a 
base address in one specified register and an index 
value in a second specified register. 


Input/Output. These instructions transfer bytes, words, 
or blocks of data between peripheral devices and the 
Z-VMPU registers or main memory. 


Z·VMPU Control. These instructions modify Z-VMPU 
control and status registers or perform those functions 
that do not fit into any of the preceding. instruction 
groups. 


Extended. These instructions perform Extended Pro- 
cessor Unit (EPU) internal operations, data transfers be- 
tween memory and EPU, data transfers between EPU 
and the Z-VMPU, and data transfers between EPU flag 
registers and the Z-VMPU Flag And Control Word (FCW). 


Processor Flags 


The processor flags contained by the program status 
registers provide a link between sequentially executed 
instructions. The link is provided in the sense that the 
result of executing one instruction may alter one or more 
flags. The new flag values (states) can then be used to 
determine the operation of a subsequent instruction 
(typically a conditional jump instruction). The following 
six flags are available for use by the programmer and the 
processor: 


EI 
Carry (C) 


D " Zero (Z) 


m Sign (S) 


II Parity/Overflow (PIV) 


II Decimal-Adjust (D) 


III 
Half Carry (H) 


Table 1. Condition Codes 


CC Field 
Code Meaning 
Flag Settings 
Binary 
Hex 


F 
Always false 
0000 
0 


T 
Always true 
1000 
8 


Z 
Zero 
Z = 1 
0110 
6 


NZ 
Not zero 
Z = 0 
1110 
E 
C 
Carry 
C = 1 
0111 
7 
NC 
No carry 
C=O 
1111 
F 
PL 
Plus 
8 = 0 
1101 
0 


MI 
Minus 
8 = 1 
0101 
5 
NE 
Not equal 
Z = 0 
1110 
E 
EQ 
Equal 
Z = 1 
0110 
6 


OV 
Overflow 
PN = 1 
0100 
4 


NOV No overflow 
PN = 0 
1100 
C 


PE 
Parity is even 
PN = 1 
0100 . 
4 


PO 
Parity is odd 
PN = 0 
1100 
C 
GE 
Greater than or equal (signed) 
(8 XOR PN) = 0 
1001 
9 
LT 
Less than (signed) 
(8 XOR PN) = 1 
0001 
1 


GT 
Greater than (signed) 
[Z OR (8 XOR PN)] = 0 
1010 
A 


LE 
Less than or equal (signed) 
[Z OR (8 XOR PN)] = 1 
0010 
2 
UGE Unsigned greater than or equal 
C=O 
1111 
F 
ULT Unsigned less than 
C = 1 
0111 
7 
UGT Unsigned greater than 
[(C = 0) AN 0 (Z = 0)] = 1 
1011 
B 
ULE Unsigned less than or equal 
(C OR Z) = 1 
0011 
3 


Noto: Some condition codes have identical flag settings and binary fields in the instruction, i.e., Z = EO, NZ = NE, C = ULT, NC = UGE, OV = PE, 
NOV = PO. 


Condition Codes 


Flags C, Z, S, and PIV are used to control the operation 
of conditional instructions (such as Conditional Jump). 
The operations performed by this type of instruction de· 
pend on whether or not a specified Boolean condition ex- 


MUL TI·MICROPROCESSOR RESOURCE 
CONTROL 


The Z8003 and Z8004 Z-VMPUs include both hardware 
and software support for controlling access to shared 
resources in multi-microprocessor systems. Z-VMPU 
pins MT (Multi-Micro In) and MO (Multi-Micro Out) and in- 
structions MSET (Set MO), MREQ (access request), 
MBIT (Test MI), and MRES (reset MO) can be used to 


ists on the four flags. Sixteen functions of the flag set- 
tings found to be frequently used are encoded in a 4-bit 
condition code (CC) field, which forms a part of all condi- 
tional instructions. These 16 codes are described in 
Table 1. 


form a prioritized resource access control system. Such 
a system WOUld, for a Z-VMPU, 1), issue requests for ac- 
cess to a shared resource, 2) test the access status for 
,the resource (available/not available) and 3) when ac- 
cess is granted, exclude all other Z-VMPUs in the system 
from the resource until use of the resource is complete. 
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TEST AND SET ~NSTRUCTION (TSEn 


The 
TSET 
instruction 
implements 
synchronization 
mechanisms in multiprogramming and multiprocessing 
. environments. TSET tests and sets semaphores that 
control access to shared resources. The testing and set- 
ting of a semaphore requires the semaphore to be read 
from memory, modified, then written back into the same 
memory location. To prevent other processors from re- 


. questing access to a resource during a test and set pro- 


cess, status code 1111 is placed onto status lines 
STo-ST3 during the data read transaction to specify that 


EXTENDED PROCESSING ARCHITECTURE 


The Z-VMPU has an Extended Processing Architecture 
(EPA) facility which extends the basic functions of the 
Z-VMPU by using external devices called Extended Pro- 
cessing Units (EPUs). A special set of extended instruc- 
tions controls the operations to be performed by each 
EPU. When a Z-VMPU encounters an extended instruc- 


EXCEPTIONS 


The"Z8003 and Z8004 Z-VMPUs support four types of ex- 
ceptions (conditions that alter the normal flow of pro- 
gram execution): interrupts, traps, instruction aborts, 
and reset. 


Interrupt and Trap Structure 


The Z8003 and Z8004 Z-VMPUs have a flexible and 
powerful interrupt and trap structure. Interrupts are ex- 
ternal events requiring Z-VMPU attention and are 
generally triggered by peripherals needing service. 
Traps are synchronous events resulting from the execu- 
tion of certain instructions. 


Both Z8003 and Z8004 Z-VMPUs support three inter- 
rupts: nonmaskable (NMI), vectored (VI), and nonvec- 
tored (NVI). . 


Both Z-VMPUs support several types of traps: System 
Call, EPU instruction, and privileged instruction. In addi- 
. tion, the Z8003 supports a Segment! Address Translation 
(SAn trap. Of the above traps, only the last is initiated by 
external events. Such events are normally generated by 
a memory management system. The remaining traps oc- 
cur when instructions limited to the System mode are 
used in the Normal'mode, when a System Call instruc- 
tion is executed, or when an EPA instruction is en- 
countered. 


The descending order of priority for traps and interrupts 
is: internal traps, nonmaskable interrupts, segment!ad- 
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an uninterruptable memory operation is taking place. 
Status code 1111 is particularly useful in a multiple 
microprocessor environment to permit external circuitry 
to preclude memory access by another device between 
the read transaction and the write transaction of the test 
and set operation. Request input BUSREQ is also dis- 
abled during a test and set operation to ensure that the 
test and set operation is not interrupted; this action is 
useful in a single-processor system. 


tion, it either traps the instruction, or it performs the data 
transfer portion of the instruction. The data manipulation 
portion of the instruction is executed by the involved 
EPU. Whether the Z-VMPU traps or transfers data 
depends on the setting of an EPA bit in its Flag and Con- 
trol Word (FCW) status register. 


dress translation traps, vectored interrupts, and nonvec- 
tored interrupts. 


When an interrupt or trap occurs, the current program 
status information is automatically pushed onto the 
System stack. The new program status is then 
automatically loaded into the Program Status registers 
from the Program Status Area in System program 
memory; This area of memory is identified by the Pro- 
gram Status Area Pointer (PSAP). 


Instruction Abort Function 


The Z-VMPU monitors its ABORT input during each bus 
transaction it generates. The timing for ;:in Instruction 
Abort operation is shown in Figure 7. If the ABORT input 
is asserted during clock cycle T2 of a memory access, 
the currently executing instruction is automatically 
aborted. If no abort is indicated but input WAIT is 
asserted, input ABORT is also tested during each wait 
cycle (T w). When an Instruction Abort condition is in- 
dicated (ABORT is asserted) the WAIT input must also be 
asserted for five cycles to permit the Z-VMPU internal 
control mechanism to abort the current instruction. 
When the WAIT input is deasserted, the Z-VMPU 
acknowledges any pending interrupt request. Therefore, 
the memory management circuitry that caused the inter- 
rupt to be aborted should also request an interrupt to the 
software routine that restores the Z-VMPU registers and 
the main memory s6 that the aborted instruction can be 
reissued; 
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Figure 7. Instruction Abort Timing 


VIRTUAL MEMORY SYSTEMS 


Virtual memory systems permit programs to reference 
an address space that exceeds the main (physical) 
memory. In virtual memory systems, high-speed main 
memory is supported by medium- and low-speed storage 
devices (secondary memory) such as hard disks or flop- 
py disks. When a Z-VMPU in a virtual system issues an 
address that references information not in main 
memory, a software swap operation must be initiated. 
This swap retrieves the block containing the referenced 
location, loads it into main memory, and restarts the 
aborted mainstream program at the pOint of interruption. 


, The swap operation is transparent to the user and to the 
executing program; therefore, the system appears to 
have a memory that is not constrained by physical size. 
The maximum size of a virtual memory is determined by 
the address structure used and by the capabilities of the 
system memory management hardware and software. 


Segmented and' Paged Virtual Memories 


External circuitry can be used to implement either a 
segmented virtual memory or a paged virtual memory. In 
a segmented virtual memory, information is transferred 
between main memory and secondary storage devices 
on a segment-by-segment basis. The Z8003 Z-VMPU 
permits use of variable-length segments of up to 64K 
bytes. 


In a paged virtual memory system, each segment is 
divided into fixed-size pages (standard size is 2048 
bytes). Main memory is divided into page ','frames." In- 
formation is then transferred between main memory and 
the secondary storage devices on a page-by-page basis. 
The Z8003 Z-VMPU can support both segmented or 
paged virtual memory systems. The Z8004 supports,only 
the paged virtual memory approach. 
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External Hardware Support 


The detection of a logical address that references a loca- 
tion outside main memory (Le., an addressing fault) and 
the initiation of the required swap operation must be per- 
formed by memory management circuitry external to the 
Z-VMPU. 


A swap operation is started by the initiation of a 
Segment/Address Translation (SAT) trap request func- 
tion in the Z-VMPU. Since the Z8004 does not have a 
SAT input, one of the NMI, VI or NVI inputs must be used 
instead. Low levels on Z-VMPU inputs ABORT, SAT and 
WAIT initiate SAT requests. 


These inputs are sampled at the falling clock of the sec- 
ond clock cycle of a bus transaction. Input WAIT must be 
asserted for at least five clock cycles. Input ABORT must 
be deasserted on or before the riSing edge of the WAIT 
Signal. The same timing can be used for both WAIT and 
ABORT. Input SAT should be asserted until the trap~ 
acknowledge bus transaction is indicated by Z8003 
Z-VMPU status code 0100. 


External circuitry is needed to record the information for 
instruction restart. The following assumptions about the 
operating system must also be true: 


II The fault handler does not generate a fault until all 


critical di:lta is saved. 


II Accessing the System stack never causes a fault. 
(Either the segment is in memory or a memory 
management mechanism warns of a potential stack 
overflow.) 


II I/O buffers are always in main memory, so I/O in- 


structions never cause a fault. 
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m The Program Status Area is always in main memory. 


The following information must be saved by external cir- 
cuitry to restart the instruction interrupted by the ad- 
dressing fault: 


• 
The value of the Program Counter during the initial 
instruction fetch cycle (cycle identified by status 
code 1101). 


1'1 
The address that caused the fault. 


II The code that was on the status lines during the 
aborted cycle. 


• 
For paged memories, the numb.er of successful data 
accesses made by the instruction. 


Software Support 


The software required for virtual memory operation nor- 
mally consists of a fault handler and a restart routine. 
The fault handler is started during each Z-VMPU abort 
request operation. The fault handler is responsible for 
saving information about the aborted instruction and for 
the initiation of a request which brings the segment (or 
page) containing the referenced location in main 


BUS TRANSACTIONS 


Status Outputs 


The Z-VMPUs provide output that specifies the type of 
transaction on the Address/Data bus. Output line R/W 
specifies whether a read or write operation is involved. 
Output line B/W specifies whether the transaction in- 
volves byte or word data. Output lineNi§" specifies the 
mode of operation, Normal or System. In addition to 


Figure 8. Flow Chart of an Instruction Restart Routine 
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memory. The state of the aborted program (Flag and 
Control Word (FCW), Program Counter (PC), and the 
register file must be saved and another process dis- 
patched while the misSing segment (or page) is being 
fetched from secondary memory. 


When the page or segment containing the referenced 
location is loaded into main memory, an instruction 
restart routine must be executed. This instruction restart 
routine must restore the.operatin,g environment that ex- 
isted when the instruction/program abort was initiated. 
This routine must establish the PC value that points to 
the aborted instruction. It must also decode the instruc- 
tion's opcode to determine whether or not any of the 
Z-VMPU's registers were modified before the instruction 
execution cycle in which the abort occurred. If registers 
were modified, the instru~tion restart routine must return 
these registers to a state in which the restarted instruc- 
tion behaves as if no abort had occurred. The flow chart 
in Figure 8 illustrates a possible control sequence for a 
software restart routine. The instructions requiring 
remodification of system registers and the manner in 
which these registers must be modified depend upon the 
type (segmented or paged) of virtual memory system im- 
plemented. 


these lines, output lines ST o-ST 3 encode additional 
characteristics of the current bus transaction. These 
lines can present any of sixteen 4-bit status codes which 
define specific characteristics of the current bus trans- 
action. The available status codes are listed and defined 
in Table 2. 


ST3-STO 
Binary 


0000 
0001 
0010 
001 1 
0100 


01 01 
01 1 0 
o 1 1 1 
1000 
1 001 
101 0 


1 0 1 1 


1 100 
1 1 0 1 
1 1 1 0 


1 1 1 1 


Table 2. Status Codes 


Definition 


Internal Operation 
Memory Refresh 
I/O Reference 
Special I/O Reference (e.g., to an MMU) 
Segment/Address Translation Trap 
Acknowledge 
Nonmaskable Interrupt Acknowledge 
Nonvectored Interrupt Acknowledge 
Vectored Interrupt Acknowledge 


Data Memory Request 
Stack Memory Request 
Data Memory Request (Extended Process- 
ing Architecture) 
Stack Memory Request, (Extended Process- 
ing Architecture) 
Instruction Space Access 
Instruction Fetch, First Word 
Extended Processing Unit-Z-VMPU 
Transfer 
Bus Lock, Data Memory Request 
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Memory Read and Write 


~emory read and instruction fetch cycles are identical, 
except for the status code on the STo-ST3 outputs;' 
Memory write is similar to memory read except for the 
RIW status and the timing of DS and data valid true. Dur- 
ing a memory cycle, a 16-bit offset address is placed on 
the ADo-AD15 outputs early in the first clock period 
(Figure 9). In the Z8003, a 7-bit segment number is also 
output on SNo-SNs one clock period earlier than the 
16-bit address offset. Issuing the segment number early 
minimizes address translation overhead by enabling the 
memory management circuitry to overlap its operations 
with the Z-VMPU instruction execution cycle. 


1 
T2 


A valid address is indicated by the rising edge of Address 
Strobe (AS). Status and mode information becomes valid 
early in the memory access cycle and remains stable 
throughout it. The access cycle can be extended in 
length by the addition of wait cycles. 


The ReadlWrite line (RIW) indicates the direction of the 
data transfer. R/W is High for transfers to the Z-VMPU. 
RIW is Low for transfers from the Z-VMPU. 


Word data (BIW is Low) to or from the Z-VMPU is 
transmitted on lines ADo-AD15. Byte data to the Z-VMPU 
is transmitted in AD10-AD7, from odd addresses 
(ADo = 1) and in ADa-AD15 from even addresses 
(ADo = 0). Byte data from the Z-VMPU is replicated in 
ADo-AD7 and ADa-AD15, regardless of address. 
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Figure 9. Memory Read and Write Timing 
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1/0 Transactions 


1/0 transactions, which are generated by the execution 
of 1/0 instructions, move data to or from peripherals or 
Z-VMPU support devices. As shown in the timing 
diagram presented in Figure 10, 1/0 transactions have a 
minimum length of four clock cycles; wait cycles can be 
added to lengthen transaction periods to meet the needs 
of slow peripherals. Status line outputs indicate whether 
access is to the Standard 1/0 (0010) or Special 1/0 (0011) 
address spaces. 


1/0 transactions are always performed with the Z-VMPU 
in System mode (NiS = Low). The rising edge of AS in- 
dicates that a valid address is present on lines 


T1 
T2 


CLOCK 
I 
I 
- 


WAIT 


-ex 


STATUS 


(B/W. ST.-STa) - 


NIS 


-~ 
AS 


MREQ 


INPUT 


-ex 


AD 
PORT ADDRESS 
~>------- 
- 


I- 


Ds 


R/W J 
- 


OUTPUT 


-:x 


AD 
PORT ADDRESS 
- 


Ds 


- r\ 


I 
R/W 


. 


ADo-AD15. Since the 1/0 address is always 16 bits long, 
the segment number lines in Z8003 are undefined. 


For byte transfers (BIW = High) in Standard 1/0 space, 
addresses must be odd; for byte transfers in Special I/O 
space, addresses must be even. 


Word data (BIW = Low) to or from the CPU is transmit- 
ted on ADo-AD15' Byte data (BIW = High) is transmitted 
on ADo-AD15 for Special I/O. This allows peripheral 
devices or CPU support devices to attach to only eight of 
the 16 ADo-AD16 lines. The Read/Write line (R/W) in- 
dicates the direction of the data transfer: peripheral-to- 
CPU (Read: R/W = High) or CPU-to-peripheral (Write: 
RIW = Low). 


TWA 
Ta 
. 


It 
I 
r--- 


I 
XQS A"" INSERT WAIT STATE(SJ AT THIS TIME 


LOW 


HIGH 


c=0 C 


~ 


DATA OUT 


r 


Figure 10. Input/Output Transaction 
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Wait Add·On Cycles 


As shown in Figures 9 and 10, the WAIT input"line is 
sampled on a falling edge of ClK one cycle before data 
is sampled (DS is low for a read or write operation). If 
the WAIT input line is low when sampled, another cycle 
is added to the transaction before data is sampled or DS 
is deasserted (goes High). During an added wait cycle, 
input WAIT is sampled again on the falling clock edge; if 
it is low, another wait cycle is added to the transaction. 
This use of the WAIT input permits transactions to be ex- 
tended arbitrarily to accommodate, for example, slow 
memories or 1/0 devices that are not yet ready for data 
transfer. 


Memory Refresh Timing 


When the 6-bit prescaler in the refresh counter has been 
decremented to zero, a refresh cycle is started (Figure 
11). The 9-bit refresh counter value is put on ADo-ADa; 
lines ADg-AD15 are undefined. Unless disabled, the 
presettable prescaler runs continuously, therefore any 
delay in starting a refresh cycle is not cumulative. 


While the STOP input is low, a continous stream of 
memory refresh cycles is executed without using the 
refresh prescaler. The refresh count, however, is in- 
cremented. 


Internal Operation Timing 


Certain instructions, such as multiply and divide, need 
additional time to execute internal operations. In these 
cases, the Z-VMPU goes through a sequence of internal 
operation machine cycles, each three to eight clock 
cycles long (Figure 12). This allows fast response to bus 
and refresh requests because a bus request or a refresh 


CLOCK 


STo-ST. 


REFRESH ADDRESS >------- -------- -C 


RlW. B/W. Mis }_-+-___ 
-+_S_,AM_EA_S P_RE_VIO_US+-CY_CLE ___ -+-__ 


Figure 11. Memory Refresh Timing 
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cycle can be inserted at the end of any internal machine 
cycle. 


Although the address outputs during clock cycle T1 are 
undefined, Address Strobe (AS) is generated to satisfy 
the requirements of Z-BUS-compatible peripherals and 
self-refresh dynamic memories. 


Reset Function 


A low on the RESET input causes the following results 
within five clock cycles (Figure 13): 


1. ADo-AD15 are 3-stated. _ 
2. AS, DS, MREQ, BUSACK, MO, and ST o-ST 3 are forced 
High. 
3. SNo-SN6 are forced low. 
4. Refresh is dis6.::Jicd. 
5. RIW, BIW and Nis are undefined. 


When RESET is again High, the Z8003 Z-VMPU executes 
three memory read cycles in a System mode of opera- 
tion. During these three word read cycles, the Z-VMPU 
reads, in sequence, the following information from seg- 
ment 0: 


1. The flag and control word (FCW) from offset location 


0002. 


2. The Program Counter segment number from location 


0004 and offset from location 0006. 


In the Z8004 Z-VMPU, only two read cycles are per- 
formed. During the first cycle, the FCW is read from 
location 0002. During the second cycle, the 16-bit PC 
value is read from location 0004. The program is started 
during the following machine cycle. 


T, 
T, 
T. 


CLOCK 


STo-ST. 
INTERNAL OPERATION 


AD 
)-- 
'--__ +-J 


MREQ, Os, R/W 
HIGH 


B/W 


MIS 
SAME AS PREVIOUS CYCLE 


Figure 12. Internal Operating Timing 
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EX, 
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IF, 


\1.-..-. __ ---:--___ _ 
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/ 
--------~ 


MREQ 
/ 
------------------~ 


M 
/ 


-----------------~ 


STO-ST3 __________ -JI 
IF, 


NIS 


RIW 


BIW 


euSA« _______ -~1 


~------_____ 
~I 


Figure 13. Reset Timing 


BUS REQUEST, INTERRUPT AND 
ACKNOWLEDGE 


A Low on the BUSREO input indicates to the Z·VMPU 
that another device is requesting the address/data and 
control lines. The asynchronous BUSREQ input is syn- 
chronized at the beginning of any machine cycle (Figure 
14). If BUSREO is Low, an internal synchronous 
BUSREO signal is generated, which, after completion of 
the current machine cycle, causes the BUSACK output 
to go Low and all bus outputs to go into the high- 
impedance state. The requesting device (typically a 
DMA) can then control the bus. 


When BUSREQ is released, it is synchronized with the 
rising clock edge. The BUSACK output goes High one 
clock period later to indicate that the Z-VMPU will take 
control of the bus. 


Interrupt and Segment/Address Translation Trap 
Request and Acknowledge 


Any High-to-Low transition on the Z-VMPU's NMI input 
(Figure 15) is asynchronously edge-detected and sets 
the internal NMI latch. The VI, NVI, and SAT inputs, as 
well as the state of the internal NMllatch, are sampled at 
the beginning of T 3. 


In response to an interrupt ortrap, the subsequent IF1 
cycle is exercised. The Program Counter, however, is 
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not 
updated, 
but the 
System 
Stack 
Pointer 
is 
decremented in preparation for storing status informa- 
tion on the System stack. 


The next machine cycle is the interrupt acknowledge 
cycle. This cycle has five automatic wait states, and ad- 
ditional wait states are possible. 


After the last wait state, the Z-VMPU reads the informa- 
tion on ADo-AD15 and stores it temporarilY,to be saved 
on the stack later in the acknowledge sequence. This 
word identifies the source of the interrupt or trap. For in- 
ternal traps, the identifior is the first word of the trapped 
instruction. For external events, the identifier is the con- 
tents of the Data bus as sampled during T 3 of the 
acknowledge cycle. During nonvectored and non- 
maskable interrupts, all 16 bits can represent peripheral 
device status information. For the vectored interrupt, the 
low byte is the jump vector, and the high byte can be 
used for extra status. Fora SAT trap (assuming that a 
Zilog Z8010 Z-MMU Memory Management Unit is used) 
the high byte is the memory management unit identifier 
and the low byte is undefined. 


After the acknowledge cycle, the N/S output indicates 
the automatic change to System mode. 


2084·013 
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Figure 14. Bus Request/Acknowledge Timing 
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Figure 15. Interrupt and Segment/Address translation Trap, Request/Acknowledge Timing 
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PIN DESCRIPTIONS 


The Z8003 Z-VMPU is produced in a 48-pin package; the 
Z8004 Z-VMPU is produced in a 40-pin package. The pin 
functions of both the Z8003 and Z8004 are illustrated in 
Figure 16;" the pin assignments are illustrated in Fig~re 
17. The signal names assigned to the Z-VMPU I/O PinS 
are listed alphabetically and are described in the follow- 
ing paragraphs. 


ABORT. Abort Request (input, active Low). This input is 
used to implement virtual memory. It is asserted by ex- 
ternal circuitry when an address does not correspond to 
a location'in main memory. 


When ABORT is asserted with input SAT in the Z8003, or 
with input NMI, VI, or NVI in the Z8004, it initiates an 
Abort Interrupt in the Z-VMPU. 


ADo-AD15. Address/Data (inputs/outputs, active High, 
3-state). These multiplexed address and data lines are 
used both for I/O and memory. 


AS. Address Strobe (output, active Low, 3-state). The ris- 
ing edge of AS indicates that addresses are valid. 


BUSACtC Bus Acknowledge (output, active Low). A low 
on this line indicates that the Z-VMPU has relinquished 
control of the bus. 


BUSREQ. Bus Request (input, active Low). This line 
must be driven low to request the bus from the Z-VMPU. 


AS 
. AD,s 
BUS{ 
os 
AD,. 
TIMING 
MREC:i 
AD,. 


AD'2 


STATU{ 


REA DIWRlil: 
AD" 


NORMAL/S'i'S'FEM 
AD,o 
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AD, 
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ST. 
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{~ 


ABORT 


CPU 
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WAiT 
ZaOO3 
VMPU 
CONTROL 
_ 
STOP 
- 


RESET 


, 
BUS{ 
• CONTROL 
SN6 


SNs 


I.TERRUPTS{ :::::: 


NMI 
SN4 


lOEG"E", 
Vi 
SN. 
NUMBER 
NVi 
SN2 


SN, 


MUL TI·MICRO { 
MI 
SNo 


CONTROL 
Me 


SAT 
SEGMEtH·PAGE 
or TRANSLATION 
TRAP 


+5 V GND CLK 


BIW. Byte/Word (output, Low = Word, 3-state). This line 
defines the size of the data being transferred. 


ClK. System Clock (input). elK is a + 5 V single-phase, 
time-base input. 


DS. Data Strobe (output, active Low, 3-state). This line 
strobes data in and out of the Z-VMPU. 
MI, MO. Multi-Micro In, Multi-Micro Out (input and out- 
put, active Low). These two lines form a resource- 
request daisy chain that allows only one Z-VMPU in a 
multi-microprocessor system to access a shared 
resource at the same time. 


MREQ. Memory Request (output, active Low, 3-state). A 
low on this line indicates that a memory reference is in 
progress. 


NMI. Nonmaskable Interrupt (edge-triggered, input, ac- 
tive Low). A High-to-low transition on NMI requests a 
nonmaskable interrupt. 


N/S. Normal/System Mode (output, Low = System 
mode, 3-state). N/'S indicates the current Z-VMPU 
operating mode (System or Normal). 


NVI. Nonvectored Interrupt (input, active Low). A low on 
this line requests a nonvectored interrupt. 


RESET. Reset (input, active Low). A low on this line 
resets the Z-VMPU. 
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Figure 16. Pin Functions 
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AD. 
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Figure 17. Pin Assignments 


INSTRUCTION SET SUMMARY 


The Z8003/04 instruction set is presented in the instruc- 
tion set summary. This summary lists the .mnemonics, 
operands, addressing modes, timing, and operation for 
each instruction. 


Timing is given as the number of CPU clock cycles re- 
quired for instruction execution. Timing requirements 
are given for the three possible addressing representa- 
tions used in word, byte and long word operations: 


IJ 
NS 


[J 
SS 


IJ 
SL 


nonsegmented addresses 


segmented short-offset addresses 


segmented long-offset addresses 


The SS and SL address representations apply only to 
those instructions for which the address of the operand 


INSTRUCTION SET SUMMARY 


The Z8003/4 provides the following types of instructions: 


[J 
Load and Exchange 


IJ 
Arithmetic 


EJ 
Logical 


[J 
Prog ram Control 


2084-017 


is contained within the instruction itself. The only instruc- 
tions of this type are those using the DA and X address- 
ing modes. 


With few exceptions, timing requirements are the same 
for all instructions in either segmented or nonsegmented 
mode, except for those instructions that employ the SS 
and SL addresses. Th.e timing for these instructions will 
differ since the number of fetches needed to load the ad- 
dress, one word or two words, will vary. 


NOTE 


Timing values are given in the SS and SLcolumns of the instruction set summary 
for all addressing modes, even where the address representation does not apply. 
These values are given to indicate that the time requirements .are the same for 
both segmented and nonsegmented modes. 


IJ 
Bit Manipulation 


IJ 
Rotate and Shift 


[J 
Block Transfer and String Manipulation 


[iJ 
Input/Output 


[] CPU Control 
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Load and Exchange 


Clock Cycles 


Addr. 
Word, Byte 
Long Word 
Mnemonics 
Operands 
Modos 
NS 
SS 
SL 
NS 
SS 
SL 
Operation 


CLR 
dst 
R 
7 
7 
7 
Clear 
CLRB 
IR 
8 
8 
8 
dst - 
0 


DA 
11 
12 
14 
X 
12 
12 
15 


EX 
R,src 
R 
6 
6 
6 
Exchange 
EXB 
IR 
12 
12 
12 
R - 
src 
DA 
15 
16 
18 
X 
16 
16 
19 


LO 
R,src 
R 
3 
3 
3 
5 
5 
5 
Load Into Register 


LOB 
1M 
7 
7 
7 
11 
11 
11 
R - 
src 


LOL 
1M 
5(byte only) 
IR 
7 
7 
7 
11 
11 
11 
DA 
9 
10 
12 
12 
13 
15 
X 
10 
10 
13 
13 
13 
16 
BA 
14 
14 
14 
17 
17 
17 
BX 
14 
14 
14 
17 
17 
17 


LO 
dst,R 
IR 
8 
8 
8 
11 
11 
11 
Load Into Memory (Store) 
LOB 
DA 
11 
12 
14 
14 
15 
17 
dst - 
R 


LOL 
X 
12 
12 
15 
15 
15 
18 
BA 
14 
14 
14 
17 
17 
17 
BX 
14 
14 
14 
17 
17 
17 


LO 
dst, 1M 
IR 
11 
11 
11 
Load Immediate Into Memory 


LOB 
DA 
14 
15 
17 
dst - 
1M 


X 
15 
15 
18 


LOA 
R,src 
DA 
12 
13 
15 
Load Address 
X 
13 
13 
16 
R - 
source address 
BA 
15 
15 
15 
BX 
15 
15 
15 


LOAR 
R,src 
RA 
15 
15 
15 
Load Address Relative 
R - 
source address 


LOK 
R,src 
1M 
5 
5 
5 
Load .Constant 
R - 
n (n = 0 ... 15) 


LOM 
R,src,n 
IR 
11 
11 
11 
Load Multlp!e 


DA 
14 
15 
17 
+3n 
R - 
src (n consecutive words) 
X 
15 
15 
18 
(n = 1 ... 16) 


LOM 
dst,R,n 
IR 
11 
11 
11 
Load Multiple (Store Multiple) 


DA 
14 
15 
17 
+3n 
dst ~ R (n consecutive words) 
X 
15 
15 
18 
(n = 1 ... 16) 


LOR 
R,src 
RA 
14 
14 
14 
17 
17 
17 
Load Relative 


LORB 
R - 
src 


LORL 
(range -32768 ... + 32767) 


LOR 
dst,R 
RA 
14 
14 
14 
17 
17 
17 
Load Relative (Store Relative) 
LORB 
dst - 
R 


LORL 
(range -32768 ... + 32767) 


POP 
dst,IR 
R 
8 
8 
8 
12 
12 
12 
Pop 


POPL 
IR 
12 
12 
12 
19 
19 
19 
dst - 
IR 


DA 
·16 
16 
18 
23 
23 
25 
Autoincrement contents of R 
X 
16 
16 
19 
23 
23 
26 


PUSH 
IR,src 
R 
9 
9 
9 
12 
12 
12 
Push 
PUSHL 
1M 
12 
12 
12 
Autodecrement contents of R 


IR 
13 
13 
13 
20 
20 
20 
IR - 
src 
DA 
13 
14 
16 
21 
21 
23 
X 
14 
14 
17 
21 
21 
24 
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Arithmetic 


Clock Cycles 


Addr. 
Word, Byte 
Long Word 
Mnemonics 
Operands 
Modes 
NS 
SS 
SL 
NS 
SS 
SL 
Operation 


ADC 
. R,src 
R 
5 
5 
5 
Add with Carry 
ADCB 
R - 
R + carry + src 


ADD 
R,src 
R 
4 
4 
4 
8 
8 
8 
Add 
ADDB 
1M 
7 
7 
7 
14 
14 
14 
R - 
R + src 
ADDL 
IR 
7 
7 
7 
14 
14 
14 
DA 
9 
10 
12 
15 
16 
18 
X 
10 
10 
13 
16 
16 
19 


CP 
R,src 
R 
4 
4 
4 
8 
8 
8 
Compare with Register 
CPB 
1M 
7 
7 
7 
14 
14 
14 
R - src 
CPL 
IR 
7 
7 
7 
14 
14 
14 
DA 
9 
10 
12 
15 
16 
18 
X 
10 
10 
13 
16 
16 
19 
~ 
~ 
~ 
CP 
dst,IM 
IR 
11 
11 
11 
Compare with Immediate 
e 


CPB 
DA 
14 
15 
17 
dst -1M 
W 


X 
15 
15 
18 
~ 


DAB 
dst 
R 
5 
5 
5 
Decimal Adjust 
ft1 
ct1 
~ 


DEC 
dst,n 
R 
4 
4 
4 
Decrement by n 
~ 


DECB 
IR 
11 
11 
11 
dst - 
dst - n 
e3 


DA 
13 
14 
16 
(n = 1 ... 16) 
X 
14 
14 
17 


DIV 
R,src 
R 
107 
107 
107 
744 
744 
744 
Dlvldo (signed) 


DIVL 
1M 
107 
107 
107 
744 
744 
744 
Word: Rn+ 1 - 
Rn,n+ 1 + src 


IR 
107 
107 
107 
744 
744 
744 
Rn - 
remainder 
DA 
108 
109 
111 
745 
746 
748 
Long Word: Rn+2,n+3 - 
Rn ... n+3 + src 
X 
109 
109 
112 
746 
746 
749 
Rn, n + 1 - 
remaind~r 


EXTS 
dst 
R 
11 
11 
11 
11 
11 
11 
Extend Sign 
EXTSB 
Extend sign of low order half of dst 


EXTSL 
through high order half of dst 


INC 
dst,n 
R 
4 
4 
4 
Increment by n 


INCB 
IR 
11 
11 
11 
dst - 
dst + n 
DA 
13 
14 
16 
(n = 1 ... 16) 
X 
14 
14 
17 


MULT 
R,src 
R 
70 
70 
70 
282* 
282* 
282* Multiply (signed) 
MULTL 
1M 
70 
70 
70 
282* 
282* 
282* 
Word: Rn,n+ 1 - 
Rn + 1 • src 


IR 
70 
70 
70 
282* 
282* 
282* 
Long Word: Rn ... n+3 - 
Rn+2,n+3 • src 
DA 
71 
72 
74 
283* 
284* 
286* * Plus seven cycles for each 1 in the 
X 
72 
72 
75 
284* 
284* 
287* 
absolute value of the low order word of 
the multiplicand 


NEG 
dst 
R 
7 
7 
7 
Negate 
NEGB 
IR 
12 
12 
12 
dst - 
-dst 
DA 
15 
16 
18 
X 
16 
16 
19 


SBC 
R,src 
R 
5 
5 
5 
Subtract with Carry 


SBCB 
R - 
R - src - carry 


SUB 
R,src 
R 
4 
4 
4 
8 
8 
8 
Subtract 


SUBB 
1M 
7 
7 
7 
14 
14 
14 
R - 
R - src 


SUBL 
IR 
7 
7 
7 
14 
14 . 
14 
DA 
9 
10 
12 
15 
16 
18 
X 
10 
10 
13 
16 
16 
19 
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Logical 


Clock Cycles 


Addr. 
Word, Byte 
Long Word 
Mnemonics 
Operands 
Modes 
NS 
SS 
SL 
NS 
SS 
SL 
Operation 


AND 
ANDB 
R,src 
R 
4 
4 
4 
And 


1M 
7 
7 
7 
R - 
RAND src 


IR 
7 
7 
7 
DA 
9 
10 
12 
X 
10 
10 
13 


COM 
dst 
R 
7 
7 
7 
Complement 


COMB 
IR 
12 
12 
12 
dst - 
NOT dst 
DA 
15 
16 
18 
X 
16 
16 
19 


OR 
R,src 
R 
4 
4 
4 
OR 
ORB 
1M 
7 
7 
7 
R - 
R OR src 


IR 
7 
7 
7 
DA 
9 
10 
12 
X 
10 
10 
13 


TEST 
dst 
R 
7 
7 
7 
13 
13 
13 
Test 


TESTB 
IR 
8 
8 
8 
13 
13 
13 
dst OR 0 
TESTL 
DA 
11 
12 
14 
16 
17 
19 
X 
12 
12 
,15 
17 
17 
20 


TCC 
cC,dst 
R 
5 
5 
5 
Test Condition Code 
TCCB 
Set LSB if cc is true 


XOR 
R,src 
R 
4 
4 
4 
exclusive OR 


XORB 
1M 
7 
7 
7 
R - 
R XOR src 


IR 
7 
7 
7 
DA 
9 
10 
12 
X 
10 
10 
13 


Program Control 


Clock Cycles 


Addr. 
Word, Byte 
Long Word 
Mnemonics 
Operands 
Modes 
NS 
SS 
S'L 
NS 
SS 
SL 
Operation 


CALL 
dst 
IR 
10 
15 
15 
Call Subroutine 


DA 
12 
18 
20 
Autodecrement SP 


X 
13 
18 
21 
@ SP - 
PC 
PC - 
dst 


CALR 
dst 
RA 
10 
15 
15 
Call Relatlvo 
Autodecrement SP 


@ SP - 
PC 
PC - 
PC + dst 
(range -4094 to + 4096) 


DJNZ 
R,dst 
RA 
11 
11 
11 
Decremont and Jump If Non·Zero 


DBJNZ 
R - 
R-1 


If R *- 0: PC - 
PC + dst 
(range -254 to 0) 


IRET* 
13 
16 
16 
Interrupt Return 
PS - 
@ SP 


Autoincrement SP 


JP 
cC,dst 
IR 
10 
15 
15 
(taken) 
Jump Conditional 
IR 
7 
7 
7 
(not taken) 
If cc is true: PC - 
dst 
DA 
7 
8 
10 


X 
8 
8 
11 
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Program Control (Continued) 


Clock Cyclos 


Addr. 
Word, Byte 
Long Word 
Mnomonics 
Operands 
Modes 
NS 
SS 
SL 
NS 
SS 
SL 
Oporation 


RET 
cc 
10 
13 
13 
(taken) 
Roturn Conditional 


7 
7 
7 
(not taken) 
If cc is true: PC - 
@SP 


Autoincrement SP 


SC 
src 
1M 
33 
39 
39 
Systom Call 
Autoincrement SP 
@ SP - 
Old PS 
Push Instruction 
PS - 
System Call PS 


BIT 
dst,b 
R 
4 
4 
4 
Tost Bit Static 
BITB 
IR 
,8 
8 
8 
Z flag - 
NOT dst bit specified by b 
DA 
10 
11 
13 
N 
X 
11 
11 
14 
00 
0 
BIT 
dst,R 
R 
10 
10 
10 
Tost Bit Dynamic 
C 
BITB 
Z flag - 
NOT dst bit specified by 
(:) 


contents of R 
• 
1M 
·Privileged instructions. Executed in system mode only. 
• 
CI • 
Bit Manipulation 
.., 
c::I 


Clock Cycles 


Addr. 
Word, By to 
Long Word 
Mnemonics 
Oporands 
Modos 
NS 
SS 
SL 
NS 
S5 
SL 
Oporatlon 


RES 
dst,b 
R 
4 
4 
4 
Rosot Bit Static 
RESB 
IR 
11 
11 
11 
Reset dst bit specified by b 
DA 
13 
1ll 
16 
X 
14 
14 
17 


RES 
dst,R 
R 
10 
10 
10 
Resot Bit Dynamic 
RESB 
Reset dst bit specified by contents R 


SET 
dst,b 
R 
4 
4 
4 
Sot Bit Static 
SETB 
IR 
11 
11 
11 
Set dst bit specified by b 


SET 
dst,R 
R 
10 
10 
10 
Sot Bit Dynamic 
-SETB 
Set dst bit specified by contents of R 


TSET 
dst 
R 
7 
7 
7 
Tost and Sot 
TSETB 
IR 
11 
11 
11 
S flag - 
MSB of dst 
DA 
14 
15 
17 
dst - 
all 1s 
X 
15 
15 
18 


Rotate and Shift 


Clock Cyclos 


Addr. 
Word, By to 
Long Word 


Mnemonics 
Operands 
Modos 
NS 
SS 
SL 
NS 
SS 
SL 
Oporatlon 


RLDB 
R,src 
R 
9 
9 
9 
Rotato Loft Digit 


RRDB 
R,src 
R 
9 
9 
9 
Rotato Right Digit 


RL 
dst,n 
R 
6 for n = 1 
Rotato Loft 
RLB 
R 
7 for n=2 
Rotate dst by n bits (n = 1,2) 


RLC 
dst,n 
R 
6 fO'r n = 1 
Rotato Loft through Carry 
RLCB 
R 
7 for n=2 
Rotate dst by n bits (n = 1,2) 


RR 
dst,n 
R 
6 for n = 1 
Rotato Right 


RRB 
R 
7 for n=2 
Rotate dst by n bits (n = 1,2) 
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Rotate and Shift (Continued) 


Clock Cycles 


Addr. 
Word, Byte 
Long Word 
Mnemonics 
Operands 
Modes 
NS 
SS 
SL 
NS 
SS 
SL 
Operation 


RRC 
dst,n 
R 
6 for n= 1 
Rotate Right through Carry 
RRCB 
R 
7 for n=2 
Rotate dst by n bits (n = 1,2) 


SDA 
dst,R 
R 
(15 + 3n) 
(15 + 3n) 
Shift Dynamic Arithmetic 
SDAB 
Shift dst left or right by contents of R 
SDAL 


SDL 
dst,R 
R 
(15 + 3n) 
(15 + 3n) 
Shift Dynamic Logical 
SDLB 
Shift dst left or right by contents of R 
SDLL 


SLA 
dst,n 
R 
(13 + 3n) 
(13 + 3n) 
Shift Left Arithmetic 
SLAB 
Shift dst left by n bits 
SLAL 


SLL 
dst,n 
R 
(13 + 3n) 
(13 + 3n) 
Shift Left Logical 
SLLB 
Shift dst left by n bits 
SLLL 


SRA 
dst,n 
R 
(13 + 3n) 
(13 + 3n) 
Shift Right Arithmetic 
SRAB 
Shift dst right by n bits 
SRAL 


SRL 
dst,n 
/R 
(13 + 3n) 
(13 + 3n) 
Shift Right Logical 
SRLB 
Shift dst right by n bits 
SRLL 


Block Transfer and String Manipulation 


Clock Cycles 


Addr. 
Word, Byte 
Long Word 
Mnemonics 
Operands 
Modes 
NS 
SS 
SL 
NS 
SS 
SL 
Operation 


CPD 
Rx,sre, 
IR 
20 
20 
20 
Compare and Decrement 
CPDB 
Ry,ee 
Rx - sre 
Autodeerement sre address 
Ry - 
Ry - 1 


CPDR 
Rx,src, 
IR 
(11 + 9n) 
Compare, Decrement and Repeat 
CPDRB 
Ry,ce 
Rx - sre 
Autodeerement sre address 
Ry-Ry-1 
Repeat until ec is true or Ry = 0 


CPI 
Rx,src, 
IR 
20 
20 
20 
Compare, Decrement and Repeat 
CPDRB 
Ry,ee 
Rx - sre 
Autodeerement sre address 
Ry - 
Ry-1 


CPIR 
Rx,sre, 
IR 
(11 + 9n) 
Compare, Increment and Repeat 


CPIRB 
Ry,ce 
Rx - sre 
Autoinerement src address 
Ry - 
Ry-1 
Repeat until ec is true or Ry = 0 


CPSD 
dst,sre, 
IR 
25 
25 
25 
Compare String and Decrement 
CPSDB 
R,ee 
dst - 
src 
Autodeerement dst and sre addresses 
R - 
R-1 


CPSDR 
dst,sre, 
IR 
(11 + 14n) 
Compare String, Decrement and Repeat 
CPSDRB 
R,ee 
dst - 
src 
Autodeerement dst and src addresses 
R - 
R-1 
Repeat until ee is true or R = 0 
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Block Transfer and String Manipulation (Continued) 


Clock Cycles 


Addr. 
Word, Byte 
Long Word 


Mnemonics 
Operands 
Modes 
NS 
SS 
SL 
NS 
SS 
SL 
Operation 


CPSI 
dst,src, 
IR 
25 
25 
25 
Compare String and Incremont 
CPSIB 
R,cc 
dst - src 
Autoincrement dst and src addresses 
R +- R-1 


CPSIR 
dst,src, 
IR' 
(11 + 14n) 
Comparo String, Incromon~ and Ropeat 


CPSIRB 
R,cc 
dst - src 
Autoincrement dst and src addresses 
R +- R-1 
Repeat until cc is true or R = 0 


LDD 
dst,src, R 
IR 
20 
20 
20 
Load and Docromont 
LDDB 
dst +- src 
N 
Autodecrement dst and src addresses 
03 
R +- R-1 
8 


LDDR 
dst,src, R 
IR 
(11 + 9n) 
Load, Decromont and Ropoat 
W 


LDDRB 
dst +- src 
;;; 


Autodecrement dst and src addresses 
't'i 
R +- R-1 
IItI 


Repeat until R = 0 
• 
l1iJ 
LDI 
dst,src, R 
IR 
20 
20 
20 
Load and Incromont 
C1 
LDIB 
dst +- src 
Autoincremerit dst and src addresses 
R - 
R-1 


LDIR 
dst,src, R 
IR 
(11 + 9n) 
Load, Incromont and Ropoat 


LDIRB 
dst +- src 
Autoincrement dst and src addresses 
R +- R-1 
Repeat until R = 0 


TRDB 
dst,src, R 
IR 
25 
25 
25 
Translate and Docremont 
dst +- src (dst) 
Autodecrement dst address 
R +- R-1 


TRDRB 
dst,src, R 
IR 
(11 + 14n) 
Translate, Decromont and Ropeat 
dst +- src (dst) 
Autodecrement dst address 
R +- R-1 
Repeat until R = 0 


TRIB 
dst,src, R 
IR 
25 
25 
25 
Translate and Increment 
dst +- src (dst) 
Autoincrement dst address 
R - 
R-1 


TRIRB 
dst,src, R 
IR 
(11 + 14~) 
Translate, Increment and Ropoat 
dst +- src (dst) 
Autoincrement dst address 
R +- R-1 
Repeat until R = 0 


TRTDB 
src1, src2, R 
IR 
25 
25 
25 
Translate and Test, Docrement 
RH1 +- src 2 (src1) 
Autodecrement src1 address 
R - 
R-1 


TRTDRB 
src1 ,src2, R 
IR 
(11 + 14n) 
Translate and Tost, Decroment 
and Repeat 
RH1 +- src2 (src1) 
Autodecrement src1 address 
R - 
R-1 
Repeat until R = 0 or RH1 = 0 
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Block Transfer and String Manipulation (Continued) 


Clock Cycles 


Addr. 
Word, Byte 
Long Word' 
Mnemonics 
Operands 
Modes 
NS 
SS 
SL 
NS 
SS 
SL 
Operation 


TRTIB 
src1, src2, R 
IR 
25 
25 
25 
Translate and Test, Increment 
RH1 - 
src2 (src1) 
Autoincrement src1 address 
R - 
R-1 


TRTIRB 
src1 ,src2, R 
IR 
(11 + 14n) 
Translate and Test, Increment 
and Repeat 
RH1 - 
src2 (src1) 
Autoincrement src1 address 
R - 
R-1 
Repeat until R = 0 or RH1 = 0 


Input/Output 


Clock Cycles 


Addr. 
Word, Byte 
Long Word 
Mnemonics 
Operands 
Modes 
NS 
SS 
SL 
NS 
SS 
SL 
Operation 


IN· 
R,src 
IR 
10 
10 
10 
Input 
INB· 
DA 
12 
12 
12 
R - 
src 


IND· 
dst,src,R 
IR 
21 
21 
21 
Input and Decrement 


INDB· 
dst - 
src 
Autodecrement dst address 
R - 
R-1 


IN DR· 
dst,src, R 
IR 
(11 + 10n) 
Input, Decrement and Repeat 


INDRB· 
dst - 
src 
Autodecrement dst address 
R - 
R-1 
Repeat until R = 0 


INI· 
dst,src, R 
IR ( 
21 
21 
21 
Input and Increment 
INIB· 
dst - 
src 
Autoincrement dst address 
R - 
R-1 


INIR· 
dst,src,R 
IR 
(11 + 10n) 
Input, Increment and Repeat 


INIRB· 
dst - 
src 
Autoincrement dst address 
R - 
R-1 
Repeat until R = 0 


OUT· 
dst,R 
IR 
10 
10 
10 
Output 
OUTB· 
DA 
12 
12 
12 
dst - 
R 


OUTD· 
dst,src, R 
IR 
21 
21 
21 
Output and Decrement 


OUTDB· 
dst - 
src 
Autodecrement src address 
R - 
R-1 


OTDR· 
dst,src,R 
IR 
(11 + 10n) 
Output, Decrement and Repeat 


OTDRB· 
dst - 
src 
Autodecrement src address 
R - 
R-1 
Repeat until R = 0 


OUTI· 
dst,src,R 
IR 
21 
21 
21 
Output and Increment 
OUTIB· 
dst - 
src 
Autoincrement src address 
R - 
R-1 
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Input/Output (Continued) 


Clock Cycles 


Addr. 
Word, Byte 
Long Word 
Mnemonics 
Operands 
Modes 
NS 
SS 
SL 
NS 
SS 
SL 
Operation 


OTIR* 
dst,src, R 
IR 
(11 + 10n) 
Output, Increment and Repeat 


OTIRB* 
dst - 
src 
Autoincrement src address 
R - 
R-1 
Repeat until R = 0 


SIN* 
R,src 
DA 
12 
12 
12 
Special Input 
SINB* 
R - 
src 


SIND* 
dst,src, R 
IR 
21 
21 
21 
Special Input and Decrement 


SINB* 
dst - 
src 
Autodecrement dst address 
R - 
R-1 
N 


Special Input, Decrement and Repeat 
CD 
SINDR* 
dst,src, R 
IR 
(11 + 10n) 
§ 
SINDRB* 
dst - 
src 
Autodecrement dst address 
• 


R - 
R-1 
Repeat until R = 0 
" 
CI 
SINI* 
dst,src,R 
IR 
21 
21 
21 
Special Input and Increment 
• 
SINIB* 
dst - 
src 
.. 


Autoincrement dst address 
CI 


R - 
R-1 


SINIR* 
dst,src, R 
IR 
(11 + 10n) 
Special Input, Increment and Repeat 


SINIRB* 
dst - 
src 
Autoincrement dst address 
R - 
R-1 
Repeat until R = 0 


SOUT* 
dst,src 
DA 
12 
12 
12 
Special Output 
SOUTe* 
dst - 
src 


SOUTD* 
dst,src, R 
IR 
21 
21 
21 
Special Output and Decrement 


SOUTDB* 
dst - 
src 
Autodecrement src address 
R - 
R-1 


SOTDR* 
dst,src, R 
IR 
(11 + 10n) 
Special Output, Decrement and Repeat 


SOTDRB* 
dst - 
src 
Autodecrement src address 
R - 
R-1 
Repeat until R = 0 


SOUTI* 
dst,src,R 
IR 
21 
21 
21 
Special Output and Increment 
SOUTIB* 
dst - 
src 
Autoincrement src address 
R - 
R-1 


SOTIR* 
dst,src, R 
R 
(11 + 10n) 
Special Output, Increment and Repeat 


SOTIRB* 
dst - 
src 
Autoincrement src address 
R - 
R ~ 1 
Repeat until R = 0 


*Privileged instructions. Executed in system mode only. 
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CPU Control 


Clock Cycles 


Addr. 
Word, Byte 
Long Word 
Mnemonics 
Operands 
Modes 
NS 
SS 
SL 
NS 
SS 
SL 
Operation 


COMFLG 
flags 
7 
7 
7 
Complement Flag 
(Any combination of C,Z,S,PIV) 


01* 
int 
7 
7 
7 
Olsable Interrupt 
(Any combination of NVI, VI) 


EI* 
int 
7 
7 
7 
Enable Interrupt 
(Any combination of NVI, VI) 


HALT* 
(8 + 3n) 
HALT 


LOCTL* 
CTLR,src 
R 
7 
7 
7 
Load Into Control Register 
CTLR - 
src 


LOCTL* 
dst,CTLR 
R 
7 
7 
7 
Load from Control Register 
dst - 
CTLR 


LOCTLB 
FLGR,src \ 
R 
7 
7 
7 
Load Into Flag Byte Register 
FLGR - 
src 


LOCTLB 
dstFLGR 
R 
7 
7 
7 
Load from Flag Byte Register 
dst - 
FLGR 


LOPS* 
src 
IR 
12 
16 
16 
Load Program Status 


DA 
16 
20 
22 
PS - 
src 
X 
17 
20 
23 


MBIT* 
7 
7 
7 
Test Multl·Mlcro Bit 
Set S if MI is Low; 
clear S if MI is High 


MREQ* 
dst 
R 
(12 + 7n) 
Multl·Mlcro Request 


MRES* 
5 
5 
5 
Multl·Mlcro Reset 


MSET* 
5 
5 
5 
Multl·Mlcro Set 


NOP 
7 
7 
7 
No Operation 


RESFLG 
flag 
7 
7 
7 
Reset Flag 
(Any combination of C,Z,S,PIV) 


SETFLG 
flag 
7 
7 
7 
Set Flag 
(Any combination of C,Z,S,PIV) 


·Prlvlleged Instructions. Executed In system mode only. 
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Extended Instructions 


Function 


Memory - 
EPU 


EPU - 
Memory 


CPU - 
EPU Registers 


EPU - 
CPU Registers 


Flags +- EPU 


EPU +- Flags 


EPU Internal Operations 


Addr. 
Modes 


IR 
X 
DA 


IR 
X 
DA 


Clock Cycles 


N5 
55 
5L 


(11 + 3n) 
(11 + 3n) 
(11 + 3n) 
(15 + 3n) (15 + 3n) 
(18 + 3n) 
(14 + 3n) 
(15 + 3n) (17 + 3n) 


(11 + 3n) 
(11 + 3n) 
(11 + 3n) 
(15 + 3n) 
(15 + 3n) (18 + 3n) 
(14 + 3n) (15 + 3n) 
(17 + 3n) 


(11 + 4n) (11 + 4n) 
(11 + 4n) 


(11 + 4n) 
(11 + 4n) (11 + 4n) 


15 
15 
15 


15 
15 
15 


Operation 


Load Memory from EPU 
Write n words from EPU into memory 


Load EPU from Memory 
Read n words from memory into EPU 


Load VMPU from EPU 
Transfer n words from EPU to Z-VMPU registers 


Load EPU from VMPU 
Transfer n words from Z-VMPU registers to EPU 


Load FCW from EPU 
Load information from EPU into flags of the 
Z-VMPU's Flag and Control Word 


Load EPU from FCW 
Transfer information from Z-VMPU's Flag and 
Control Word to EPU 


(11 + 4n) 
(11 + 4n) (11 + 4n) 
Internal EPU Operations 
Z-VMPU treats this template. as a "no-operations"; 
it is typically used to initiate an internal EPU 
operation. The character is a field in the 
instruction. 
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ABSOLUTE MAXIMUM RATINGS 


Voltages on all inputs and outputs 
with respect to GND ............... -0.3 V to + 7.0 V 


Operating Ambient Temperature ....... ooe to + 70°C 


Storage Temperature.' ............ -65°C to + 150 °e 


STANDARD TEST CONDITIONS 


Standard test temperature/operating voltage ranges are 
presented below. All voltages are referenced to GND. 
Positive current flows into the referenced pin. 


• 
ooe to + 70°C, + 4.75 V ~ Vee ~ + 5.25 V 


!II 
-40°C to + 85°C, + 4.75 V ~ Vee ~ + 5.25V 
a 
-55°C to + 125°C, + 4.5 V ~ Vee ~ + 5.5V 


All ac parameters assume a load capacitance of 100 pF 
max, except for parameter 6, which has a load 
capacitance of 50 pF max. Timing references between 
two output signals assume a load difference of 50 pF 
max. 


DC CHARACTERISTICS 


Symbol 
Parameter 
Min 


Stresses greater than those listed under Absolute Maximum Ratings 
may cause permanent damage to the device. This is a stress rating 
only; operation of the device at any condition beyond those indicated in 
the operational section of this specification is not implied. Exposure to 
absolute maximum rating conditions for extended periods may affect 
device reliability. 


+5V 


Figure 18. Standard Test Load 


Max 
Unit 
Condition 


VCH 
Clock Input High Voltage 
Vcc-O.4 
Vcc+ 0.3 
V 
Driven by External Clock Generator 


VCl 
Clock Input Low Voltage 
-0.3 
0.45 
V 
Driven by External Clock Generator 


VIH 
Input High Voltage 
2.0 
Vce+ 0.3 
V 
Vil 
Input Low Voltage 
-0.3 
0.8 
V 
VOH 
Output High Voltage 
2.4 
V 
IOH = -250 A 


VOL 
Output Low Voltage 
0.4 
V 
IOl = +2.0 mA 


III 
Input Leakage 
± 10 
A 
0.4 VIN + 2.4 V 


IOl 
Output Leakage 
±10 
A 
0.4 VOUT + 2.4 V 


lee 
Vee Supply Current 
300 
mA 


AC CHARACTERISTICSt 


Z80031Z8004 
Z8003A1Z8004A Z80038/Z80048 


(4 MHz) 
(6 MHz) 
(10 MHz) 
Number 
Symbol 
Parameter 
Min 
Max 
Min 
Max 
Min 
Max 


1 
TcC 
Clock Cycle Time 
250 
2000 
165 
2000 
100 
2000 


2 
TwCh 
Clock Width (High) 
105 
2000 
70 
2000 
40 


3 
TwCI 
Clock Width (Low) 
105 
2000 
70 
2000 
40 


4 
TfC 
Clock Fall Time 
20 
10 
10 


5 
TrC. 
Clock Rise Time 
20 
15 
10 


6 
TdC(SNv) 
Clock t to Segment Number Valid 
130 
110 
70 
(50 pF load) 
7 
TdC(SNn) 
Clock t to Segment Number Not Valid 
20 
10 
5 
8 
TdC(Bz) 
Clock t to Bus Float 
65 
55 
40 


9 
TdC(A) 
Clock t to Address Valid 
100 
75 
50 
10 
TdC(Az) 
Clock t to Address Float 
65 
55 
40 


11 
TdA(DR) 
Address Valid to Read Data Required Valid 
475* 
305* 
180* 
12 
TsDR(C) 
Read Data to Clock I Setup Time 
30 
20 
10 


13 
TdDS(A) 
DS t to Add ress Active 
80* 
45* 
20* 


14 
TdC(DW) 
Clock t to Write Data Valid 
100 
75 
50 


15 
ThDR(DS) 
Read Data-to DS t Hold Time 
0 
0 
0 


16 
TdDW(DS) 
Write Data Valid to DS t Delay 
295* 
195* 
110* 
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2084-018 


AC CHARACTERISTICSt (Continued) 


Z8003/Z8004 
Z8003A1Z8004A Z8003 B/Z8004 B 
(4 MHz) 
(6 MHz) 
(10 MHz) 
Number 
Symbol 
Parameter 
Min 
Max 
Min 
Max 
Min 
Max 


17 
TdA(MR) 
Address Valid to MREQ 1 Delay 
55 
35* 
20'" 


18 
TdC(MR) 
Clock 1 to MREQ 1 Delay 
80 
70 
40 


19 
TwMRh 
MREQ Width (High) 
210* 
135* 
80* 
20 
Td'MR(A) 
MREQ 1 to Address Not Active 
70* 
35* 
20* 


21 
TdDW(DSW) 
Write Data Valid to OS 1 (Write) Delay 
55* 
35* 
15* 
22 
TdMR(DR) 
MREQ 1 to Read Data Required Valid 
375* 
230* 
140* 


23 
TdC(MR) 
Clock 1 MREQ t Delay 
80 
60 
45 
24 
TdC(ASf) 
Clock t to AS 1 Delay 
80 
60. 
40 


25 
TdA(AS) 
Address Valid to AS t Delay 
55* 
35* 
20* 


26 
TdC(ASr) 
Clock 1 to AS t Delay 
90 
80 
40 


27 
TdAS(DR) 
AS t to Read Data Required Valid 
360* 
220* 
140* 


28 
TdDS(AS) 
OS t to AS 1 Delay 
70* 
35* 
15* 
29 
TwAS 
AS Width (Low) 
85* . 
55* 
30* 
30 
TdAS(A) 
AS t to Address Not Active Delay 
70* 
45* 
20* 
00 


31 
TdAz(DSR) 
AddresUJoat to OS (Read) 1 Delay 
0 
0 
0 
§ 
32 
TdAS(DSR) 
AS t to OS (Read) 1 Delay 
80* 
55* 
30* 


33 
TdDSR(DR) 
OS (Read)JJ.o Read Data Required Valid 
205* 
130* 
70* 
W 


34 
TdC(DSr) 
Clock 1 to OS t Delay 
70 
65 
45 
~ 
35 
TdDS(DW) 
OS t to Write Data Not Valid 
75* 
45* 
25* 
tta 
36 
TdA(DSR) 
Address Valid to OS (Read) 1 Delay 
180* 
110* 
65* 
~ 
37 
TdC(DSR) 
Clock t to OS (Read) 1 Delay 
120 
85 
60 
~ 
38 
TwDSR 
OS (Read) Width (Low) 
275* 
185* 
110* 
~ 
39 
TdC(DSW) 
Clock 1 to OS (Write) 1 Delay 
95 
80 
60 
d 
40 
TwDSW 
OS (Write) Width (Low) 
185* 
110* 
75* 
41 
TdDSI(DR) 
OS (I/O) 1 !Q.Bead Data Required Valid 
330* 
210* 
120* 


42 
TdC(DSf) 
Clock 1 to OS (I/O) 1 Delay 
120 
90 
60 


43 
TwOS 
OS (I/O) Width (Low) 
410* 
255* 
160* 


44 
TdAS(DSA) 
AS t to OS j6cknowledge) 1 Delay 
1065* 
690* 
410* 


45 
TdC(DSA) 
Clock t to OS (Acknowledge) 1 Delay 
120 
85 
65 
46 
TdDSA(DR) 
OS (Acknowledge) 1 to Read Data 
455* 
295* 
165* 
Required Delay 


47 
TdC(S) 
Clock t to Statu.§...Valid Delay 
110 
85 
60 


48 
TdS(AS) 
Status Valid to AS t Delay 
50* 
30* 
10* 


49 
TsR(C) 
RESET to Clock t Setup Time 
180 
70 
50 
50 
ThR(C) 
RESET to Clock t Hold Time 
0 
0 
0 


51 
TwNMI 
NMI Width (Low) 
100 
70 
50 


52 
TsNMI(C) 
N.Ml...!Q.. Clock t Setup Time 
140 
70 
50 
53 
TsVI(C) 
VI, NVI to Clock t Setup Time 
110 
50 
40 


54 
ThVI(C) 
VI, NVI to Clock t Hold Time 
20 
20 
10 


55 
TsSGT(C) 
SAT to Clock t Setup Time 
70 
55 
40 


56 
ThSGT(C) . 
SAT to Clock t Hold Time 
0 
0 
0 


57 
TsMI(C) \ 
MI to Clock t Setup Time 
180 
110 
80 


58 
ThMI(C) 
MI to Clock t Hold Time 
0 
0 
0 


59 
TdC(MO) 
Clock t to MO Delay 
120 
85 
70 
60 
TsSTP(C) 
STOP to Clock 1 Setup Time 
140 
80 
50 


61 
ThSTP(C) 
STOP to Clock 1 Hold Time 
0 
0 
0 


62 
TsW(C) 
WAIT to Clock 1 Setup Time 
50 
30 
20 


63 
ThW(C) 
WAIT to Clock 1 Hold Time 
10 
10 
5 
64 
TsBRQ(C) 
BUSREQ to Clock t Setup Time 
90 
80 
60 


65 
ThBRQ(C) 
BUSREQ to Clock t Hold Time 
10 
10 
5 
66 
TdC(BAKr) 
Clock t to BUSACK t Delay 
100 
75 
60 


67 
TdC(BAKf) 
Clock t to BUSACK 1 Delay 
100 
75 
60 


68 
TwA 
Address Valid Width 
150* 
95* 
50* 


69 
TdDS(S) 
OS t to STATUS Not Valid 
80* 
55* 
30* 
70 
TsABT(C) 
ABORT l'to Clock t Setup Time 
50 
30 
25 
71 
ThABT(C) 
ABORT 1 to Clock 1 Hold Time 
0 
0 
0 


*Clock·cycle·time·dependent characteristics. See table on 
following page. 


tTimings are preliminary and subject to change. Units in 
nanoseconds(ns). 
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CLOCK·CYCLE·TIME·DEPENDENT CHARACTERISTICS 


Z8003 
Z8003A 
Z8003B 


Numbor 
Symbol 
Equation 
Equation 
Equation 


11 
TdA(DR) 
2TcC + TwCh -130 ns 
2TcC + TwCh - 95 ns 
2TcC + TwCh - 60 ns 
13 
TdDS(A) 
TwCI- 25 ns 
TwCI- 25 ns 
TwCI- 20 ns 
16 
TdDW(DS) 
TcC + TwCh - 60 ns 
TcC + TwCh - 40 ns 
TcC + TwCh - 30 ns 


17 
TdA(MR) 
TwCh - 50 ns 
TwCh - 35 ns 
TwCh- 20 ns 
19 
TwMRh 
TcC - 40 ns 
TcC - 30 ns 
TcC-20 ns 


20 
TdMR(A) 
TwCI- 35 ns 
TwCI- 35 ns 
TwCI- 20 ns 


21 
TdDW(DSW) 
TwCh - 50 ns 
TwCh - 35 ns 
TwCh - 25 ns 
22 
TdMR(DR) 
2TcC -130 ns 
2TcC - 100 ns 
2TcC - 60 ns 


25 
TdA(AS) 
TwCh - 50 ns 
TwCh - 35 ns 
TwCh- 20 ns 
27 
TdAS(DR) 
2TcC - 140 ns 
2TcC -110 ns 
2TcC - 60 ns 
N 


28 
TdDS(AS) 
TwCI- 35 ns 
TwCI- 35 ns 
TwCI- 25 ns 
00 


29 
TwAS 
TwCh - 20 ns 
TwCh -15 ns 
TwCh -10 ns 
8 
30 
TdAS(A) 
TwCI- 35 ns 
TwCI- 25 ns 
TwCl- 20 ns 
W • 
32 
TdAS(DSR) 
TwCI- 25 ns 
TwCI- 15 ns 
TwCI-10 ns 
It' 
33 
TdDSR(DR) 
TcC + TwCh -150 ns 
TcC + TwCh - 105 ns 
TcC + TwCh - 70 ns 
-S 


35 
TdDS(DW) 
TwCI- 30 ns 
TwCI·- 25 ns 
TwCI- 15 ns 
:I 


36 
TdA(DSR) 
TcC -70 ns 
TcC-55 ns 
TcC-35 ns 
• 
CI 


38 
TwDSR 
TcC + TwCh - 80 ns 
TcC + TwCh - 50 ns 
TcC + TwCh - 30 ns 


40 
TwDSW· 
TcC- 65 ns 
TcC - 55 ns 
TcC - 25 ns 


41 
TdDSI(DR) 
2TcC -170 ns 
2TcC-120 ns 
2TcC- 80 ns 
43 
TwDS 
2TcC - 90 ns 
2TcC -75 ns 
2TcC- 40 ns 
44 
TdAS(DSA) 
4TcC + TwCI - 40 ns 
4TcC + TwCI- 40 ns 
4TcC + TwCI - 30 ns 
46 
TdDSA(DR) 
2TcC + TwCh -150 ns 
2TcC + TwCh - 105 ns 
2TcC + TwCh - 75 ns 
48 
TdS(AS) 
TwCh - 55 ns 
TwCh - 40 ns 
TwCh - 30 ns 


68 
TwA 
TcC - 90 ns 
TcC -70 ns 
TcC - 50 ns 


69 
TdDS(S) 
TwCI- 25 ns 
TwCI- 15 ns 
TwCI- 10 ns 


ORDERING INFORMATION 


Product 
Packagel 
Product 
Packagel 
Number 
Temp 
Speed 
Description 
Number 
Temp 
Speed 
Description 


Z8003 
CS 
4.0 MHz 
Z-VMPU (48-pin) 
Z8004 
CS 
4.0 MHz 
Z-VMPU (40-pin) 


Z8003A 
CS 
6.0 MHz 
(same as above) 
Z8004A 
CS 
6.0 MHz 
(same as above) 


Z8003B 
CS 
10.0 MHz 
(same as above) . 
Z8004B 
CS 
10.0 MHz 
(same as above) 


NOTES: e = Ceramic; S = o·e to 70·e 
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Features 


General 
Description 


2046-051, 033 


II Dynamic segment relocation makes software 
addresses independent of physical memory 
addresses. 


a Sophisticated memory-management features 
include access validation that protects 
memory areas from unauthorized or 
unintentional access, and a write-warning 
indicator that predicts stack overflow. 


II For use with both 28001 and 28003 CPU. 


The 28010 Memory Management Unit (MMU) 


manages the large 8M byte addressing spaces 
of the 28001 CPU. The MMU provides dynamic 
segment relocation as well as numerous 
memory protection features. 
DynamiC segment relocation makes user soft- 
ware addresses independent of .the physical 
memory addresses, thereby freeing the user 
from specifying where information is actually 
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Figure 1. Pin Functions 
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t.'l 64 variable-sized segments from 256 to 
65,536 bytes can be mapped into a total 
physical address space of 16M bytes; all 64 
segments are randomly accessible. 


13 Multiple MMUs can support several transla- 
tion tables for each 28001/3 address space. 


Ii! MMU architecture supports multi-program- 
ming systems and virtual memory implemen- 
tations. 


located in the physical memory. It also pro- 
vides a flexible, efficient method for support- 
ing multi-programming systems. The MMU 
uses a translation table to transform the 23-bit 
logical address output from the 28001 CPU 
into a 24-bit address for the physical memory. 
(Only logical memory addresses go to an MMU 
for translation; 110 addresses and data, in 
general, must by pass this component.) 
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Figure 2. Pin Assignments 
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Memory segments are variable in size from 
256 bytes to 64K bytes, in increments of 256 
bytes. Pairs of MMUs support the 128 segment 
numbers available for the various Z8001 CPU 
address spaces. Within an address space, any 
number of MMUs can be used to accommodate 
multiple translation tables for System and Nor- 
mal operating modes, or to support more 
sophisticated memory-management systems. 


MMU memory-protection features safeguard 
memory areas from unauthorized or unin- 
tended access by associating special access 
restrictions with each segment. A segment is 
assigned a number of attributes when its 
descriptor is entered into the MMU. When a 
memory reference is made, these attributes are 
checked against the status information sup- 
plied by the Z8001/3 CPU. If a mismatch oc- 


SEGMENT NUMBER 
OFFSET/DATA 


SNo-SNe 
ADa-AD15 


ST o-ST 3 
SEGf 
SUP 
RiW. NJ~ 


STATUS 
SEGMENT SUPPRESS PHYSICAL 
INFORMATION 
TRAP 
ADDRESS 
REGUEST 


curs, a trap is generated and the CPU is inter- 
rupted. The CPU can then check the status 
registers of the MMU to determine the cause. 
Segments are protected by modes of permit- 
ted use, such as read only, system only, 
execute only and CPU-access only. Other seg- 
ment management features include a write- 
warning zone useful for stack operations and 
status flags that rec~rd read or write accesses 
to each segment. 
The MMU is controlled via 22 Special 1/0 


instructions from the Z8000 CPU in System 
mode. With these instructions, system software 
can assign program segments to arbitrary 
memory locations, restrict the use of segments 
and monitor whether segments have been read 
or written. 


SEGMENT NUMBER 
OFFSET/DATA 


SNo-SNa 
ADa-AD,s 


STo-ST, 
!miT 
SUP 


RiW,NJ~ 


STATUS 
SEGMENT SUPPRESS PHYSICAL 
INFORMATION 
TRAP 
ADDRESS 
REQUEST 


Figure 3. The shaded areas in these block diagrams illustrate the resources used in the two modes of MMUoperation. In 
the Address Translation Mode shown on the left. addresses are translated automatically. In the Command Mode shown 
on the right. specific registers are accessed using Special 1/0 commands. 
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A segmented addressing space-compared 
with linear addressing-is closer to the way a 
programmer uses memory because each pro- 
cedure and data set can reside in its own 
segment. 
The 8M byte Z8001 addressing spaces are 
divided into 128 relocatable segments of up to 
64K bytes each. A 23-bit segmented address 
uses a 7-bit segment address to point to the 
segment, and a 16-bit offset to address any 
byte relative to the beginning of the segment. 
The two parts of the segmented address may. 
be manipulated separately. 
The MMU divides the physical memory into 
256-byte blocks. Segments consist of physically 
contiguous blocks. Certain segments may be 
designated so that writes into the last block 
generate a warning trap. If such a segment is 
used as a stack, this warning can be used to 
increase the segment size and prevent a stack 
overflow· error. 
The addresses manipulated by the program- 
mer, used by instructions and output by the 
Z8001 are called logical addresses. The MMU 
takes the logical addresses and transforms 
them into the physical addresses required for 
accessing the memory (Figure 4). This address 
transformation process is called relocation. 
The relocation process is transparent to user 
software. A translation table in the MMU 
associates the 7-bit segment number with the 
base address of the physical memory segment. 
The 16-bit logical address offset is added to the 
physical base address to obtain the actual 
physical memory location. Because a base 
address always has a low byte equal to zero, 


Each memory segment is assigned several 
attributes that are used to provide memory 
access protection. A memory request from the 
Z8001/3 CPU is accompanied by status infor- 
mation that indicates the attributes of the 
memory request. The MMU compares the 
memory request attributes with the segment 
attributes and generates a Trap Request 
whenever it detects an attribute violation. Trap 
Request informs the Z8001/3 CPU and the 
system control program of the violation so that 
appropriate action can be taken to recover. 
The MMU also generates the Suppress signal 
SUP in the event of an access violation. Sup- 
press can be used by a memory system to inhi- 
bit stores into the memory and thus protect the 
contents of the memory from erroneous 
changes. 


. Five attributes can be associated with each 
segment. When an attempted access violates 
anyone of the attributes associated with a seg- 
ment, a Trap Request and a Suppress signal 
are generated by the MMU. These attributes 
are read only, execute only, system access 
only, inhibit CPU accesses and inhibit DMA 
accesses. 


only the high-order 16 bits are stored in the 
MMU .and used in the addition. Thus the low- 
order byte of the physical memory location is 
the same as the low-order byte of the logical 
address offset. This low-order byte therefore 
bypasses the MMU, thus reducing the number 
of pins required. 
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Figure 4. Logical-to-Physical Address Translation 


Segments are specified by a base address 
and a range of legal offsets to this base 
address. On each access to a segment, the off- 
set is checked against this range to insure that 
the access falls within the allowed range. If an 
access that lies outside the segment is attemp- 
ted, Trap·Request and Suppress are generated. 
Normally the legal range of offsets within a 
segment is from 0 to 256N + 255 bytes, where 
0:::;N:::;255. However, a segment may be 
speCified so that legal offsets range from 256N 
to 65,535 bytes, where 0:::; N:::; 255. The later 
type of segment is useful for stacks since the 
Z8000 stack manipulation instructions cause 
stacks to grow toward lower memory locations. 
Thus when a stack grows to the limit of its· 
allocated segment, additional memory can be 
allocated on the correct end of the segment. 
As an aid in maintaining stacks, the MMU 
detects when a write is performed to the lowest 
allocated 256 bytes of these segments and 
generates a Trap Request. No Suppress signal. 
is generated so the write is allowed to proceed. 
This write warning can then be used to indi- 
cate that more memory should be allocated to 
the seqment. 
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The MMU contains three types of registers: 
Segment Descriptor, Control and Status. A 
set of 64 Segment Descriptor Registers supplies 
the information needed to map logical memory 
addresses to physical memory locations. The 
segment number of a logical address deter- 
mines which Segment Descriptor Register is 
used in address translation. Each Descriptor 
Register also contains the necessary informa- 
tion for checking that the segment location 
referenced is within the bounds of the segment 
and that the type of reference is permitted. It 
also indicates whether the segment has been 
read or written. 
In addition to the Segment Descriptor 
Registers, the 28010 MMU contains' three 8-bit 
control registers for programming the device 
and six 8-bit status registers that record infor- 
mation in the event of an access violation. 


Segment Descriptor Registers. Each of the 64· 
Descriptor Registers contains a 16-bit base 
address field, an 8-bit limit field and an 8-bit 
attribute field (Figure 5). The base address 
field is subdivided into high- and low-order 
bytes that are loaded one byte at a time when 
the descriptor is initialized. The limit field con- 
tains a value N that indicates N + 1 blocks of 
256 bytes have been allocated to the segment. * 
The attribute field contains eight flags 
(Figure 6). Five are related to protecting the 
segment against certain types of access, one 
indicates the special structure of the segment, 
and two encode the types of accesses that have 
been made to the segment. A flag is set when 
its value is 1. The following brief descriptions 
indicate how these flags are used. 


Read-Only (RD). When this flag is set, the segment is read 
only and is protected against any write access. 


System-Only (SYS). When this flag is set, the segment can 
be accessed only in System mode, and is protected against 
any access in Normal mode. 


CPU-Inhibit (CPUI): When this flag is set, the segment is 
not accessible to the currently executing process, and is 
protected against any memory access by the CPU. The 
segment is, however, accessable under DMA. 


Execute-Only (EXC). When this flag is set, the segment 
can be accessed only during an instruction fetch or access 
by the relative addreSSing mode cycle, and thus is pro- 
tected against any access during other cycles. 


DMA-Inhibit (DMAI). When this flag is set, the segment 
can be accessed only by the CPU, and thus is protected 
against any access under DMA. 


Direction and Warning (DIRW). When this flag is set, the 
segment memory locations are considered to be organized 
in descending order and each write to the segment is 
checked for access to the last 256·byte block. Such an 
access generates a trap to warn of potential segment 
overflow, but no Suppress signal is generated. 


Changed (CHG); When this flag is set, the segment has 
been changed (written). This bit is set automatically during 
any write access to this segment if the write access does not 
cause any violation. 


Referenced (REF). When this flag is set, the segment has 
been referenced (either read or written). This bit is set 
automatically during any access to the segment if the 
access does not cause a violation. 


°In the stack mode, segment size is 64K-256N. 
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Figure 5. Segment Descriptor Registers 
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Figure 6. Attribute Field in Segment Descriptor Register 


Control Registers~ The three user-accessible 
8-bit control registers in the MMU direct the 
functioning of the MMU (Figure 7). The Mode 
Register provides a sophisticated method for 
selectively enabling MMUs in multiple-MMU 
configurations. The ?egment Address Register 
(SAR) selects a particular Segment Descriptor 
Register to be accessed during a control 
operation. The Descriptor Selection Counter 
Register points to a byte within the Segment 
Descriptor Register to be accessed during a 
control operation. 
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Figure 7. Control Registers 


The Mode Register contains a 3-bit iden- 
tification field (ID) that distinguishes among 
eight enabled MMUs in a multiple-MMU con- 
figuration. This field is used during the seg- 
ment trap acknowledge sequence (refer to the 
section on Segment Trap and Acknowledge). 
In addition, the Mode Register contains five 
flags. 


Multiple Segment Table (MST). This flag indicates whether 
multiple segment tables are present in the hardware con- 
figuration. When this flag is set, more than one table is 
present and the N/S line must be used to determine 
whether the MMU contains the appropriate table. 


Normal Mode Select (NMS). This flag indicates whether 
the MMU is to translate addresses when the N/S line is 
High or Low. If the MST flag is set, the N/S line must 
match the NMS flag for the MMU to translate segment 
addresses, otherwise the MMU Address lines remain 
3-stated. 
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Upper Range Select (URS). This flag is used to indicate 
whether the MMU contains the lower-numbered segment 
descriptors or the higher-numbered segment descriptors. 
The most significant bit of the segment number must match 
the URS flag for the MMU to translate segment addresses, 
otherwise the MMU Address lines remain 3-stated. 


Translate (TRNS). This flag indicates whether the MMU is 
to translate logiCal program addresses to physical memory 
locations or is to pass the logical addresses unchanged to 
the memory and without protection checking. In the non- 
translation mode, the most significant byte of the output is 
the 7-bit segment number and the most significant bit is O. 
When this flag is set, the MMU performs address transla- 
tion and attribute checking. 


Master Enable (MSEN). This flag enables or disables the 
MMU from performing its address translation and memory 
protection functions. When this flag is set, the MMU per- 
forms these tasks; when the flag is clear the Address lines 
of the MMU remain 3-stated. 


The Segment Address Register (SAR) points 
to one of the 64 segment descriptors. Control 
commands to the MMU that access segment 
descriptors implicitly use this pointer to select 
one of the descriptors. This register has an 
auto-incrementing capability so that multiple 
descriptors can be accessed in a block 
read/write fashion. 
The Descriptor Selection Counter Register 
holds a 2-bit counter that indicates which byte 
in the descriptor is being accessed during the 
reading or writing operation. A value of zero 
in this counter indicates the high-order byte of 
the base address field is to be accessed, one 
indicates the low-order byte of the base 
address, two indicates the limit field and three 
indicates the attribute field. 
Status Registers. Six 8-bit registers contain 
information useful in recovering from memory 
access violations (Figure 8). The Violation 
Type Register describes the conditions that 
generated the trap. The Violation Segment 
Number and Violation Offset Registers record 
the most-significant 15 bits of the logical 
address that causes a trap. The Instruction 
Segrp.ent Number and Offset Registers record 
the most-significant 15 bits of the logical 
address of the last instruction fetched before 
the first accessing violation. These two 
registers can be used in conjunction with 
external circuitry that records the low-order 
offset byte. At the time of the addressing'viola- 
tion, the Bus Cycle Status Register records the 
bus cycle status (status code, read/write mode 
and normal/system mode). 
The MMU generates a Trap Request for two 
general reasons: either it detects an access 


violation, such as an attempt to write into a 
read-only segment, or it detects a warning 
condition, which is a write into the lowest 256 
bytes of a segment with the DIRW flag set. 
When a Violation or warning condition is 
detected, the MMU generates a Trap Request 
and automatically sets the appropriate flags. 
The eight flags in the Violation Type Register 
describe the cause of a trap. 
Read-Only Violation (RDV). Set when the CPU attempts to 
access a read-only segment and the R/W line is Low. 


System Violation (SYSV). Set when the CPU accesses a 
system-only segment and the N/S line is High. 


CPU-Inhibit Violation (CPUIV). Set when the CPU 
attempts to access a segment with the CPU-inhibit flag set. 


Execute-Only Violation (EXCV). Set when the CPU 
attempts to access an execute-only segment in other than 
an instruction fetch or load relative instructions cycle. 


Segment Length Violation (SLV). Set when an offset falls 
outside of the legal range of a segment. 


Primary Write Warning (PWW). Set when an access is 
made to the lowest 256 bytes of a segment with the DIRW 
flag set. 


Secondary Write Warning (SWW). Set when the CPU 
pushes data into the last 256 bytes of the system stack and 
EXCV, CPUIV, SLY, SYSV, RDV or PWW is set. Once this 
flag is set, 'subsequent write warnings for accessing the 
system stack do not generate a Segment Trap request. 


Fatal Condition (FATL). Set when any other flag in the 
Violation Type Register is set and either a violation is 
detected or a write warning condition occurs in Normal 
mode. This flag is not set during a stack push in System 
mode that results in a warning condition. This flag 
indicates a memory access error has occurred in the trap 
processing routine. Once set, no Trap Request signals are 
generated on subsequent violations. However, Suppress 
signals are generated on this and subsequent CPU viola- 
tions until the FA TL flag has been reset. 
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The Z8010 MMU generates a'Segment Trap 
when it detects an access violation or a 
write warning cOndition. In the case of an 
access violation, the MMU also activates Sup- 
press, whk:h can be used to inhibit memory 
writes and to flag special data to be returned 
'on a read access. Segment Trap remains Low 
until a Trap Acknowledge signal is received. If 
a CPU-generated violation occurs, Suppress is 
asserted for that cycle and all subsequent CPU 
instruction execution cycles until the end of 
the instruction. Intervening DMA cycles are 
not suppressed, however, unless they generate 
a violation. Violations detected during DMA 
cycles cause Suppress to be asserted during 
that cycle only-no Segment Trap Requests are 
ever generated during DMA cycles. 
Segment traps to the Z8001l3 CPU are han- 
dled Similarly to other types of interrupts. To 
service a segment trap, the CPU issues a seg- 
ment trap acknowledge cycle. The acknow- 
ledge cycle is always preceded by an instruc- 
tion fetch cycle that is ignored (the MMU has 
been designed so that this dummy cycle is 
ignored). During the a'cknowledge cycle all 
enabled MMU s use the AddresslData lines to 
indicate their status. An MMU that has 
generated a Segment Trap Request outputs a 1 
on the AID line associated with the number in 
its ID field; an MMU that has not generated a 
segment trap request outputs a 0 on its 
associated 'AID line. AID lines for which no 
MMU is associated remain 3"stated. During a 


Several features of the MMU can be used in 
conjunction with external circuitry to support 
virtual memory for the Z8001l3. Segment Trap 
Request can be used to signal the CPU in the 
event that a segment is not in primary memory. 
The CPU-Inhibit Flag can be used to indicate 
'whether a segment is in the memory or in 


MMU architecture directly supports two 
methods for multiple MMU configurations. The 
first approach extends single-MMU capability , 
for handling 64 segments to a dual-MMU con- 
figuration that manages the 128 different 
segments the Z8001l3 can address. This 
scheme uses the URS flag in the Mode Register 
in connection with the high-order bit of the 
segment number (SN6). 
The 'second approach uses several MMUs to 
implement multiple translation tables. Multiple 
tables can be used to reduce the time required 
to switch tasks by assigning separate tables to 
each task. Multiple translation tables for multi- 


segment trap acknowledge cycle, an MMU 
uses AID line 8 + i if its ID field is i. 
Following the acknowledge cycle the CPU 


automatically pushes the Program Status onto 
the system stack and loads another Program 
Status from the Program Status Area. The Seg- 
ment Trap line is reset during the segment trap 
acknowledge cycle. Suppress is not generated 
during the stack push. If the store creates a 
write warning condition; a Segment Trap 
Request is generated and is serviced at the 
end of the Program Status swap. The SWW 
flag is also set. Servicing this second Segment 
Trap Request also creates a write warning con- 
dition, but because the SWW flag is set, no 
Segment Trap Request is generated. If a viola- 
tion rather than a write warning occurs during 
the Program Status swap, the FATL flag is set 
rather than the SWW flag. Subsequent viola- 
tions cause Suppress to be asserted but not 
Segment Trap Request. Without the SWW and 
FATL flags, trap processing routines that 
generate memory violations would repeatedly 
be interrupted and called to process the trap 
they created. 
The CPU routine to process a trap request 
should first check the F ATL flag to determ\ne 
if a fatal system error has occurred. If not, the 
SWW flag should be checked to determine if 
more memory is required for the system stack. 
Finally, the trap itself should be processed and 
the Violation Type Register reset. 


secondary storage. The Changed and Altered 
Flags in the attribute field for each segment 
can aid in implementing efficient segment 
management policies. The Status Registers can 
be used in recovering from virtual memory 
access faults. 


task environments can use the Master Enable 
Flag to enable the appropriate MMUs through 
software. Multiple translation tables may also 
be used to extend the physical memory size 
beyond 16 megabytes by separating system 
from normal memory and! or program from 
data memory. The MST and NMS flags in the 
Mode Register can be used in conjunction with 
the Nis line to select the MMU that contains 
the appropriate table. Special external cir- 
cuitry that monitors the CPU Status lines can 
manipulate the MMU Nis line to perform this 
selection. 


DMA 
Operation 


MMU 
Commands 


Direct memory access operations may occur 
between Z800 1 instruction cycles and can be 
handled through the MMU. The MMU permits 
DMA in either the System or Normal mode of 
operation. For each memory access, the seg- 
ment attributes are checked and if a violation 
is detected, Suppress is activated. Unlike a 
CPU violation that automatically causes Sup- 
press signals to be generated on subsequent 
memory accesses until the next instruction, 
DMA violations generate a Suppress only on a 
per memory access basis.· 
The DMA device should note the Suppress 


signal and record sufficient information to 
enable the system to recover from the access 
violation. No Segment Trap Request is ever 
generated during DMA, hence warning 
conditions are not signaled. Trap Requests are 
not issued because the CPU cannot 
acknowledge such a request. 


The various registers in the MMU can be 
read and written using Z800 1 CPU special 1/0 
commands. These commands have machine 
cycles that cause the Status lines to indicate an 
SIO operation is in progress. During these 
machine cycles the MMU enters command 
mode. In this mode, the rising edge of the 
Address Strobe indicates a command is pres" 
ent on the ADa-ADIs. If Chip Select is 
asserted and if this command indicates that 
data is to be written into one of the MMU 
registers, the data is read from ADa-ADIs 
while Data Strobe is Low. If the command indi- 
cates that data is'to be read from one of the 
MMU registers, the data is placed on 
ADa-ADIs while Data Strobe is Low. 
There are ten commands that read or write 
various fields in the Segment Descriptor 
Register. The status of the Read/Write line 
indicates whether the command is a read or a 
write. 
The auto-incrementing ·feature of the Seg- 


ment Address Register (SAR) can be used to 
block load segment descriptors using the 
repeat forms of the Special I/O instructions. 
The SAR is autoincremented at the end of the 
field. In accessing the base field, first the 
high-order byte is selected and then the low- 
order byte. The command accessing the entire 
Descriptor Register references the fields in the 
order of base address, limit and attribute. 


At the start of a DMA cycle, DMASYNC 


must go Low for at least two cldck cycles, 
indicating to the MMU the beginning of a 
DMA ,cycle. A Low DMASYNC inhibits the 
MMU from using an indeterminate segment 
number on lines SNo-SN6. When the DMA 
logical memory address is valid, the 
DMASYNC line must be High before a rising 
edge of Clock and the MMU then performs its 
address translation and access protection fu'nc- 
tions. Upon the release of the bus at the ter- 
mination of the DMA cycle the DMASYNC line 
must again be High. After two clock cycles ~f 
DMASYNC High, the MMU assumes that the 
CPU has control of the bus and that subse- 
quent memory references are CPU accesses. 
The first instruction fetch occurs at least two 
cycles after the CPU regains control of the 
bus. During CPU cycles, DMASYNC should 
always be High. 


Opcode (Hex) 


oa 
09 
OA 


OB 
OC 
OD 
OE 


Instruction 
Read/Write Base Field 
Read/Write Limit Field 
ReadlWrite Attribute Field 
Read/Write Descriptor (all fields) 
Read/Write Base Field; Increment SAR 
ReadlWrite Limit Field; Increment SAR 
ReadlWrite Attribute Field; Increment 
SAR 


OF 
ReadIWrite Descriptor; Increment SAR 
IS 
Set All CPU-Inhibit Attribute Flags 
16 
Set All DMA-Inhibit Attribute Flags 
Three commands are used to read and write 
the control registers. 
. 


Opcode (Hex) 


00 
01 
20 


Instruction 
ReadIW rite Mode Register 
Read/Write. Segment Address Register 
Read/Write Descriptor Selector Counter 
Register 
The Status Registers are read-only registers, 
although the Violation Type Register (VTR) 
can be reset. Nine instructions access these 
registers. 


Opcode (Hex) 
02 
03 
04 


OS 
06 


07 


Instruction 
Read Violation Type Register 
Read Violation Segment Number Register 
Read Violation Offset (High-byte) Register 
Read Bus Status Register 
Read Instruction Segment Number 
Register 
Read Instruction Offset (High-byte) 
Register 


II 
Reset Violation Type Register 
13 
Reset SWW Flag in VTR 


14 
Reset F ATL Flag in VTR 
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The 28010 translates addresses and checks 
for access violations by stepping through 
sequences of basic clock cycles corresponding 
to the cycle structure of the 28001 CPU. The 
following timing diagrams show the relative 
timing relationships of MMU signals during the 
basic operations of memory read/write and 
MMU control commands. For exact timing 
information, refer to the composite timing 
diagram. 
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Memory Read and Write. Memory read and 
instruction fetch cycles are identical, except 
for the status information on the ST o-ST 3 
inputs. During a memory read cycle (Figure 9) 
the 7-bit segment number is input on SNo-SN6 
one clock period earlier than the address off- 
set; a High on DMASYNC during T3 indicates 
that the segment offset data is valid. The most 
Significant eight bits of the address offset are 
placed on the ADo-AD15 inputs early in the 
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Figure 9. Memory Read Timing 
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first clock period. Valid address offset data is 
indicated by the rising edge of Address 
Strobe. Status and mode information become 
valid early in the memory access cycle and 
remain stable throughout. The most significant 
16-bits of the address (physical memory loca- 
tion) remain valid until the end of T3. Segment 
Trap Request and Suppress are asserted in T2. 


Segment Trap Request remains Low hnUl Seg- 
ment Trap Acknowledge is received. Suppress 
is asserted during the current machine cycle 
and terminates during T3. Suppress is 
repeatedly asse.rted during CPU instruction 
execution cycles until the current instruction 
has terminated. 
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Figure 10. Memory Write Timing' 
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MMU Command Cycle. During the command 
cycle of the MMU (Figure 11), commands are 
placed on the Address/Data lines during T 1. 
The Status lines indicate that a Special I/O 
instruction is in progress, and the Chip Select 
line enables the appropriate MMU for that 
command. Data to be written to a register in 
the MMU must be valid on the Address/Data 
lines late in T2. Data read from the MMU is 


placed on the Address/Data lines late in the 
TWA cycle. 
Input/Output and Refresh. Input/Output and 
Refresh operations are indicated by the status 
lines STo-ST3.During these operations, the 
MMU refrains from any address translation or 
protection checking. The address lines As-A23 
remain 3-stated. 
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Figure II. 1/0 Command Timing 
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Reset. The MMU can be reset by either hard 
ware or software mechanisms. A hardware 
reset occurs on the falling edge of the Reset 
signal; a software reset is performed by a 
28000 Special I/O command. A hardware reset 
clears the Mode Register, Violation Type 
Register and Descriptor Selection Counter. If 
the Chip Select line is Low, the Master Enable 
Flag in the Mode Register is set to 1. All other 
registers are undefined. After reset, the 
ADs-AD15 and As-A23 lines are 3-stated. The 
SUP and SEGT open-drain outputs are not 
driven. If the Master Enable flag is not set dur- 
ing reset, the MMU does not respond to subse- 
quent addresses on its AID lines. To enable an 
MMU after a hardware reset, an MMU com- 
mand must be used in conjunction with the 
Chip Select line. 
A software reset' occurs when the Reset 


'Violation Type Register command is issued. 
This command clears the Violation Type 
Register and returns the MMU to its initial 
state (as if no violations or warnings had 
occurred). Note that the hardware and software 
resets have different effects. 
Segment Trap and Acknowledge. The 28010 
MMU generates a segment trap whenever it 
detects an access violation or a write into the 
lowest block of a segment with the DIRW flag 


set. In the case of an access violation, the 
MMU also activates Suppress. This Suppress 
signal can be used to inhibit memory writes. 
The Segment Trap remains Low until a Trap 
Acknowledge signal is received. If a violation 
occurs, Suppress is asserted for that cycle and 
all subsequent CPU cycles until the end of the 
instruction; intervening DMA cycles are not 
suppressed, however, unless they generate a 
violation. Violations detected during DMA 
cycles cause Suppress to be asserted during 
that cycle only, but no Trap Request is 
generated. 
When the MMU issues a Segment Trap 
Request it awaits a Segment Trap Acknowl- 
edge. Subsequent violations occurring before 
the Trap Acknowledge is received are still 
detected and handled appropriately. During 
the Segment Trap Acknowledge cycle, the 
MMU drives one of its Address/Data lines 
High; the particular line selected is a function 
of the identification field of the mode register. 
After the Segment Trap has been acknowl- 
edged by the 2800113 CPU, the Violation 
Status Register should be read via the Special 
I/O commands in order to determine the cause 
of the trap. The Trap Type Register should also 
be reset so that subsequent traps will be 
recorded correctly. 
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Figure 12. Segment Trap and Acknowledge Timing 
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Pin 
Description 


210 


Aa-A23. Address Bus (outputs, active High, 
3-state). These address lines are the 16 most- 
significant bits of the physical memory 
location. 
ADa-ADls. Address/Data Bus (inputs/outputs, 
active High, 3-state). These multiplexed 
address and data lines are used both for com- 
mands and for logical addresses intended for 
translation. 
AS. Address Strobe (input, active Low). The 
rising edge of AS indicates that ADo-ADlS, 
STo-ST3, R/W and Nis are valid. 


CLK. System Clock (input). CLK is the 5 V 
single-phase time-base input used for both the 
CPU and MMU. 
CS. Chip Select (input, active Low). This line 
selects an MMU for a control command. 


OMASYNC. DMA/Segment Number Syn- 
chronization Strobe (input, active High). A 
Low on this line indicates that the segment 
number lines are 3-state; a High indicates that 
the segment number is valid. It must always be 
High during CPU cycles. If a DMA device 
does not use the MMU for address translation, 
the BUSACK signal from the CPU may be 
used as an input to "DMASYNC. 


OS. Data Strobe (input, active Low). This line 
provides timing for the data transfer between 
the MMU and the 2800113 CPU. 
Nis. Normal/System Mode (input, Low = 
System Mode). Nis indicates the 28001/3 CPU 
or 28016 DMA is in the Normal or System 
Mode. The signal can also be used to switch 
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between MMU s during different phases of an 
instruction. 
Reserved. Do not connect. 


RESET. Reset (input, active Low). A Low on 
this line resets the MMU. 


R/W. Read/Write (input, Low=write). R/W 
indicates the 2800113 CPU or 28016 DTC is 
reading from or writing to memory or the 
MMU. 
SEGT. Segment Trap Request (output, active 
Low, open drain). The MMU interrupts the 
2800113 CPU with a Low on this line when the 
MMU detects an 'access violation or write 
warning. 
SNo-SNs. Segment Number (inputs, active 
High). The SNo-SNs lines are used to address 
one of 64 segments in the MMU; SN6 is used to 
selectively enable the MMU. 
STo-ST3. Status (inputs, active High). These 
lines specify the 2800113 CPU status. 


5T3-5TO 
0000 
a a 01 
a a 1 a 
a 01 1 
a 1 a a 
a 1 a 1 
01 10 
a 1 1 1 
10 a a 
100 I" 
10 1 a 
101 1 
1 100 
1 101 
1 1 10 
1111 


Internal operation 
Memory refresh 
I/O reference 


Definition 


Special I/O reference (e.g., to an MMU) 
Segment trap acknowledge 
Nonmaskable interrupt acknowledge 
Nonvectored interrupt acknowledge 
Vectored interrupt acknowledge 
Data memory request 
Stack memory request 
Data memory request (EPU) 
Stack mem.ory request (EPU) 
Instruction space access 
Instruction fetch, first word 
Extension processor transfer 
Bus Lock, Data Memory Request (28003 only) 
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Figure 13. The MMU in a zaool System 
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Conditions 


DC 
Character- 
istics 


Ordering 
Information 


8085-0209 


SUP. Suppress (output, active Low, open 
drain). This signal is asserted during the cur- 


Voltages on all inputs and outputs 
with respect to GND .......... -0.3 V to + 7.0 V 
Operating Ambient 
, 


Temperature ........ See ordering information 
Storage Temperature ........ -65°C to + 150°C 


The characteristics below apply for the 
follOWing standard test conditions, unless 
otherwise noted. All voltages are referenced to 
GND. Positive current flows into the refer- 
enced pin. Standard conditions are as follows: 


C +4.75 V :::; Vcc :::; +5.25 V 
c GND = 0 V 
c O°C :::; TA :::; +70°C 


Symbol 
Parameter 
Min 
Max 


rent bus cycle when any access violation 
except write warning occurs. 


Stresses greater than those listed under Absolute Maxi- 
mum Ratings may cause permanent damage to the device. 
This is a stress rating only; operation of the device at any 
condition above those indicated in the operational sections 
of these specifications is not implied. Exposure to absolute 
maximum rating conditions for extended periods may affect 
device reliability. 


+5V 


2.2K 


FROM OUTPUT 0---__ - 
..... -1< 


UNDER TEST 


Unit 
Condition 


VCH 
Clock Input High Voltage 
VCC-O.4 
VCC+0.3 
V 
Driven by External Clock Generator 


VCL 
Clock Input Low Voltage 
-0.3 
0.45 
V 
Driven by External Clock Generator 


VIH 
Input High Voltage 
2.0 
VCC+0.3 
V 


VIL 
Input Low Voltage 
-0.3 
0.8 
V 


VOH 
Output High Voltage 
2.4 
V 
IOH = -250 p.A 


VOL 
Output Low Voltage 
0.4 
V 
IOL = +2.0 rnA 


IlL 
Input" Leakage 
±10 
p.A 
0.4 :::; VIN :::; +2.4 V 


IOL 
Output Leakage 
±10 
p.A 
0.4 :5 VIN :5 + 2.4 V 


ICC 
V CC Supply Current 
300 
rnA 


NOTE: The on-chip back-bias voltage generator takes approximately 20 ms to pump the back-bias voltage to -2.5 V after the power has 
been turned on. The performance of the 28010 2-MMU is not guaranteed during this period. 


Product 
Package/ 
Product 
Package/ 
Number 
Temp 
Speed 
Description 
Number 
Temp 
Speed 


Z8010 
CE 
4.0 MHz 
Z-MMU (48-pin) 
Z8010A 
CE 
6.0 MHz 


Z8010 
CM 
4.0 MHz 
Same as above 
Z8010A 
CM 
6.0 MHz 


Z8010 
CMB 
4.0 MHz 
Same as above 
Z8010A 
CMB 
6.0 MHz 


Z8010 
CS 
4.0 MHz 
Same as above 
Z8010A 
CS 
6.0 MHz 


Z8010 
PE 
4.0 MHz 
Same as above 
Z8010A 
PE 
6.0 MHz 


Z8010 
PS 
4.0 MHz 
Same as above 
Z8010A 
PS 
6.0 MHz 


NOTES: C = Ceramic, P = Plastic; E = -40°C to +85°C, M = -55°C to + 125°C, MB = -55°C to + 125°C with 
MIL-STD-883 Class B processing, S = O°C to + 70°C. 


Description 


Z-MMU (48-pin) 


Same as above 


Same as above 


Same as above 


Same as above 


Same as above 
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AC Characteristics . 
Z8010 
Z8010 
Z8010 


4 MHz 
6MHz 
IOMHz 


No. 
Symbol 
Parameter 
Min 
Max 
Min 
Max 
Min 
Max 
Notes*.t 


1 
TcC 
Clock Cycle Time 
250 
165 
100 


2 
TwCh 
Clock Width (High) 
105 
70 
40 


3 
TwCI 
Clock Width (Low) 
105 
70 
40 


4 
TfC 
Clock Fall Time 
20 
10 
10 


5-TrC 
Clock Rise Time 
20 
15 
10 


6 
TdDSA(RDv) 
DS I (Acknowledge) to Read Data 
100 
80 
60 


Valid Delay 
7 
TdDSA(RDf) 
DS I (Acknowledge) to Read Data 
75 
60 
45 
Float Delay 
8 
TdDSR(RDv) 
DS I (Read) to AD Output Driven Delay 
100 
80 
60 


9 
TdDSR(RDf) 
DS I (Read) to Read Data Float Delay 
75 
60 
60 
45 


10- TdC(WDv)-- CLK I to Write Data Valid Delay 
125 
80 
50 


11 
ThC(WDn) 
CLK I to Write Data Not Valid 
30 
20 
10 
Hold Time 
12 
TwAS 
Address Strobe Width 
60 
50 
30 


13 
TsOFF(AS) 
Offset Valid to AS' I Setup Time 
45 
35 
20 


14 
ThAS(OFFn) 
AS I to Offset Not Valid Hold Time 
60 
40 
20 


15 - 
TdAS(C)--- AS I to CLK I Delay 
110 
90 
'50 


16 
TdDS(AS) 
DS I to AS I Delay 
50 
30 
15 
17 
TdAS(DS) 
AS I to DS I Delay 
50 
40 
30 


18 
TsSN(C) 
SN Data Valid to CLK I Setup Time 
100 
40 
20 


19 
ThC(SNn) 
CLK I to SN Data not Valid Hold Time 
a 
a 
a 


20 - 
TdDMAS(C) - 
DMASYNC Valid to CLK I Delay 
120 
80 
60 


21 
TdSTNR(AS) 
Status (STo-ST3, NIS, R/W) Valid to 
50 
30 
10 


AS I Delay 
22 
TdC(DMA) 
CLK I to DMASYNC I Delay 
20 
15 
10 
23 
TdST(C) 
Status (STo-ST3) Valid to CLK I Delay 
100 
60 
30 


24 
TdDS(STn) 
DS I to Status Not Valid Delay 
a 
a 
a 
25 - 
TdOFF(Av)-- Offset Valid to Address Output 
175 
90 
60---1- 


Valid Delay 
26 
TdST(Ad) 
Status Valid to Address Output 
155 
75 
45 
Driven Delay 
27 
TdDS(Af) 
DS I to Address Output Float Delay 
160 
130 
100 


28 
TdAS(Ad) 
AS I to Addres Output Driven Delay 
145 
70 
40 


29 
TdC(Av) 
CLK I to Address Output Valid Delay· 
255 
155 
100 
30 - 
TdAS(SEGT)- AS I to SEGT I Delay 
160 
100 
60--1,2- 
31 
TdC(SEGT)- 
CLK I to SEGT I Delay 
300 
200 
100 
1.2 
32 
TdAS(SUP) 
AS I to SUP I Delay 
150 
90 
55 
1,2 
33 
TdDS(SUP 
DS I to SUP I Delay 
155 
100 
60 
1,2 
34 
TsCS(AS) 
Chip Select Input Valid to AS I Setup 
10 
10 
10 
Time 
35 - 
ThAS(CSn) -- AS I to Chip Select Input ~ot Valid---60 
40 
20 


Hold Time 
36 
TdAS(C) 
AS I to CLK I Delay 
a 
a 
a 
37 
TsCS(RST) 
Chip Select Input Valid to RESET I 
150 
100 
60 
Setup Time 
38 
ThRST(CSn) 
RESET I to Chip Select Input Not 
a 
a 
a 
Valid Hold Time 
39 
TwRST 
RESET Width (Low) 
2TcC 
2TcC 
2TcC 


40 - 
TdC(RDv) -- CLK I to Read Da'ta Valid Delay 
460 
300 
190 


41 
TdDS(C) 
DS I to CLK I Delay 
30 
20 
10 
42 
TdC(DS) 
CLK I to DS I Delay 
0 
a 
a 


NOTES: 
1. 50 pF Load. 
Timing measurements are made at the following voltages: 
2. 2.2K Pull-up. 
High 
Low 


• All 6 MHz timings are preliminary. 
Clock 
4.0 V 
0.8 V 


t Units in nanoseconds (ns). 
Output 
2.0 V 
0.8 V 


Input 
2.0 V 
0.8 V 


Float 
b.V 
±0.5 V 
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FEATURES 


[] 'PMMU 
architecture 
supports 
multiprogramming 
systems and virtual memory implementations. 


[J Dynamic page relocation makes software addresses 
independent of physical memory addresses. 


IJ Sophisticated memory management features include 
access validation that protects memory areas from 
unauthorized or unintentional access, and a write- 
warning indicator that predicts stack overflow. 


GENERAL DESCRIPTION 


The l8015 Paged Memory Management Unit (PMMU), a 
new member of lilog's l8000 Family, is designed to sup- 
port a paged virtual memory system for the l8003 Virtual 
Memory Processor Unit (VMPU). Although designed 
primarily for the l8003, the PMMU can also be used to 
support other CPUs in the Z8000 Family. The sophisti- 
cated memory management features of the PMMU in- 
clude access validation for memory protection, a write- 
warning that gives advance warning of possible stack 


FUNCTIONAL DESCRIPTION 


The l8015 Paged Memory Management Unit (PMMU) 
manages the 8M byte addressing spaces of the l8003 
VMPU. The PMMU provides dynamic page relocation as 
well as numerous memory protection features. 


Dynamic page relocation makes user software ad- 
dresses independent of the physical memory addresses, 
thereby freeing the user from specifying where informa- 
tion is located in the physical memory. It also provides a 
flexible, efficient method for supporting multiprogram- 
ming systems. 


, The PMMU uses a content-addressable translation table 
to transform each 23-bit logical address output from the 
VMPU into a 24-bit address for the physical memory. 
(Only logical memory addresses go to a PMMU for 
translation; I/O addresses and data bypass this compo- 
nent.) The translation table consists of 64 page descrip- 
tors; each descriptor contains address translation, 


Z8015 Z8000™ PMMU 


ll»Qg~a! Mannery 
Management Unit 


Produ.ct 
Specification 


September 1983 


[J 64 pages, each 2048 bytes in length, can be mapped 
into a total physical address space of 16 megabytes; 
all 64 pages are randomly accessible. 


[J Pages larger or smaller than 2048 bytes can be easily 
implemented. 


[] The number of accessible pages can be increased by 
using multiple PMMUs. 


overflow, and the generation of instruction aborts for ac- 
cesses to pages not in main memory. Each PMMU can 
manage a basic memory area of sixty-four 2048-byte, 
fixed-size pages. The VMPU's 8M byte logical address 
space is translated by the PMMU into a 16M byte 
physical address space. Page size can be easily 
changed and multiple PMMUs can be combined to sup- 
port more pages. 


status, and access information for one memory page. 
Each PMMU can then manage up to 64 pages of 
memory. 


Multiple PMMUs can be used to support more than 64 
pages within a given address space. In addition, PMMUs 
can be used to accommodate separate translation 
tables for System and Normal operating modes. 


The PMMU is designed to support a memory page 2048 
bytes in length. This basic page length can be increased 
or decreased using a minimal amount of external cir- 
cuitry. 


The PMMU is specially designed to operate with a l8003 
VMPU to implement a paged virtual memory system. If 
the current PMMU instruction addresses a page not in 
main memory (a page fault), the PMMU initiates an In- 
struction Abort operation in the VMPU. During an abort, 
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the PMMU aborts the execution of the current instruc- 
tion, then saves the information needed to restart the 
aborted instruction. On completion of the abort, the 
PMMU initiates a trap in the VMPU to a routine that 
brings the addressed page into main memory, updates 
the descriptor table of the PMMU to allow address 
translation to the new page, and restarts the execution 
of the interrupted instruction. 


The logical address that caused the page fault is 
available in three violation address registers of the 
PMMU. This information can be used to fetch the re- 
quired instruction or data page into main memory and/or 
to create a page descriptor entry so that the executing 
program can access those instructions or data. The 
logical address of the instruction generating the page 
fault is available in three instruction address registers of 
the PMMU. This information can be used to reset the 
Program Counter' to restart the instruction. The instruc- 
tion to be restarted must also be examined to determine 
if adjustments must be made to any VMPU registers to 
ensure correct execution. Finally, the Read/Write Data 
Count register can be accessed so that certain instruc- 
tions, such as Load Multiple, can be restarted correctly. 


As an aid in implementing efficient paging algorithms, 
the PM M U provides Changed and Referenced flags for 
each page descriptor register. The Changed flag in- 
dicates that a page has been altered and hence must be 
copied to secondary storage before that physical 
memory can be overwritten by another page. The 
Referenced flag can be used to determine which pages 
have not been 
accessed by an 
executing pro- 


gram-these are the pages that should first be removed 
from memory when room must be made to bring another 
page into memory. 


SEGMENTED ADDRESSING AND 
ADDRESS TRANSLATION 


Compared with linear addressing, a segmented address- 
ing space is closer to the way a programmer uses 
memory because each procedure and data set can 
reside in its own segment. 


The 23-bit addresses output by the VMPU divide an 8M 
byte addressing space into 128 segments of up to 64K 
bytes each. A 23-bit segmented address consists of a 
7-bit segment number and a 16-bit offset used to address 
any byte relative to the beginning of the segment. The 
two parts of the segmented address (segment number 
and offset) can be manipulated separately. 


The PMMU divides physical 'memory into 2048-byte 
pages. Pages are assumed to be allocated in memory on 
2048-byte boundaries so that the 11 low-order bits of the 
starting location of each page are always equal to zero. 
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PMMU memory protection features safeguard memory 
areas from unauthorized or unintended access by asso- 
ciating special access restrictions with each page. A 
page is assigned a number of attributes when its descrip- 
tor is initially entered into the PMMU. When a memory 
reference is made, these attributes are checked against 
the status information supplied by the VMPU. If a mis- 
match occurs, the instruction is aborted, a Trap Request 
Signal is generated, and the VMPU is interrupted. The 
VMPU then checks the status registers of the PMMU to 
determine the cause of the abort. 


Pages are protected by modes of permitted use, such as 
read only, system only, and execute only. A Valid flag in- 
dicates whether or not a descriptor has been initialized. 
Other page management features include a Write Warn- 
ing flag useful for stack operations. 


The PMMU is controlled by 20 Special I/O instructions, 
which can be issued from the VMPU in System mode 
only. With these instructions, system software can 
assign program pages to arbitrary memory locations, 
restrict the use of pages, and monitor'whether pages 
have been read or written. 


The PMMU has two operating modes: an Address Trans- 
lation 
mode 
in 
which 
addresses 
are 
translated 
automatically as they are received, and a Command 
mode, during which specific registers in the PMMU are 
accessed using Special I/O commands. Figure 1 shows 
two simplified block diagrams that illustrate the internal 
organization and data/Signal flow within the PMMU. The 
resources used in the Translation and the Command 
modes are shown, separately, in Figures 1 a and 1 b. 


Segments in a virtual memory system can consist of 
pages that need not be in physical storage. Those seg- 
ment pages in main memory need not be contiguous. 
Segments can have a variable number of pages. Certain 
pages can be designated so that writes into the last 128 
bytes generate a warning trap without causing an in- 
struction abort. If such a page is used as the last page of 
the system stack, the warning trap can be used to initiate 
the allocation of another page to the stack segment to 
prevent a stack overflow error. 


The addresses manipulated by the programmer, used by 
instructions, and output by the VMPU are called logical 
addresses. The PMMU translates logical addresses into 
the phYSical addresses required for acceSSing memory, 
this process is called relocation. 


INTERNAL DATA BUS 


IOPF 
LOW 
VOFF 
LOW 


OAR 


OFFS(T nus 


ViOUUiOU 
CHf.CKING 


r....--..I. ¢={f 


STJL-ST~ 
R/W N/S 


ADS-AD1O 


Figure 1a. Address Translation Mode PMMU Operating Modes, Simplified Flow Diagram 


The translation activity in the PMMU that provides ad- 
dress relocation is controlled by four internal control 
flags and six input lines. The four flags are: 


Mastor Enable (MSEN) Flag. This flag controls when the PMMU out- 
puts physical addresses on its Address bus (A) lines. When this bit is 
clear, the A lines remain 3-stated and no checking is performed. 
Translate (TRNS) Flag. This flag determines whether the output on 
the A lines is the logical address as input (with most significant bit at 0) 
or a translated address. When translation is not performed, no check- 
ing is done. 


Multiple Page Table (MPT) Flag. This flag indicates whether or not 
separate PMMUs are to be used for System and Normal pages. 


Normal Mode Select (NMS) Flag. When the Multiple Page Table flag 
is set, this flag indicates whether the PMMU contains System or Nor- 
mal page descriptors. 


2081-001 


The six input lines used in the control of the PMMU are: 


NIS Line. This line is used by the PMMU to distinguish 
System mode accesses from Normal mode accesses. 
When the Multiple Page Table flag is set, the NtS line 
acts as a chip-select mechanism. 


Chip Enable (CE) Line. This line acts as a master 
enable control line: it must be asserted for any address 
translation to occur or for any address to be output by 
the PMMU. 


Status Lines (STo-ST3)' These four lines are used by 
the PMMU to determine the type of transaction in pro- 
gress. 
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IOFF 
lOW 


VOFF 
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OFFSET BUS 


ADa-AD10 


VIOLATION 
CHECKING 


Figure 1 b. Command Mode PMMU Operating Modes, Simplified Flow Diagram 


Access violation checking, write warning checking, and 
page fault monitoring functions occ'ur only when the 
PMMU is enabled for address translation. For example, 
if Chip Enable is not asserted, the PMMU does not 
generate an Abort Request even if none of its descriptors 
match the logical address. 


The address translation process is transparent to user 
software; a simplified flow diagram of this process is 
shown in Figure 2. A content-addressable translation 
table in the PMMU compares the 7-bit segment number 
and five most-significant bits of the offset with the logical 
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address field of each descriptor. If a match occurs and 
that descriptor's Valid flag is set, the physical address 
field of that descriptor is accessed. The 11-bit logical ad- 
dress within the page is concatenated to this 13-bit 
physical base address to obtain the actual physical 
memory location. Because the base address of a page 
always has the low-order 11 bits equal to zero,. only the 
high-order 13 bits are stored in the PMMU and used in 
the translation. The PMMU outputs the 16 most- 
significant bits of the translated address. 


2081-002 


15 
11 10 
8 7 


LOGICAL 
r------t----t-------1 ADDRESS 


L __ 


PHYSICAL 
ADDRESS 
23 
11 10 
8 7 


~,----------__ 
v~------------J 
OUTPUT BY PMMU 


Figure 2. Logical·to·Physical Address Translation 


MEMORY PROTECTION 


Each memory page is assigned several attributes that 
are used to provide memory access protection. A 
memory request from the VMPU is accompanied by 
status information that indicates the attributes of the 
memory request. The PMMU compares the memory re- 
quest attributes with the page attributes and generates 
Instruction Abort Request, Suppress, and Trap Request 
Signals whenever it detects an attribute violation. 


An Abort Request is used to generate the Abort and Wait 
inputs to the VMPU that cause the current instruction to 
be aborted. The Suppress input is used by the VMPU to 
inhibit stores into the memory and thus protect the con- 
tents of the memory from erroneous changes. A Trap Re- 
quest informs the VMPU and the system control program 
of the violation so that appropriate action can be taken 
for recovery. 


Three attributes: read only, execute only, and system ac- 
cess only, can be associated with each page. When an 
attempted access violates anyone of the page at- 
tributes, Abort Request, Trap Request, and Suppress 
Signals are generated by the PMMU. 


Each descriptor register has a Valid flag in the attribute 
field. When set to 1, this flag indicates that the descriptor 
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contains valid translation information and its logical ad· 
dress field is to be used in the associative match pro· 
cess. If Chip Enable is asserted and no match is found, 
the PMMU, if enabled, generates Abort Request, Trap 
Request, and Suppress signals. The PMMU is enabled 
under either of the following conditions: the MSEN and 
TRNS flags are both 1 and the MPT flag is 0; or the MSEN 
and TRNS flags are both 1, the MPT flag is 1, and both in· 
put N/S and the NMS flag have the same value. 


Normally, the legal range of offsets within a segment 
goes from 0 to 65,535 bytes. A stack segment, however, 
has legal word offsets ranging downward from 65,534 to 
o bytes; the stack manipulation instructions cause 
stacks to grow toward lower memory locations. When a 
stack grows to the limit of its allocated segment, addi· 
tional memory can be added to the segment. As an aid in 
maintaining stacks, the PMMU detects when a write is . 
performed to the lowest-allocated 128 bytes of a stack 
page and generates a Trap Request if the DIRW attribute 
flag is set in the page descriptor. Since neither a Sup- 
press nor Abort Request signal is generated, the write is 
allowed to proceed. This write warning can then be used 
to indicate that more memory (that is, another page) 
needs to be allocated to the segment. 
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PMMU REGISTER ORGANIZAtiON 


The PMMU contains a set of 64 page descriptor 
registers that supply the information needed to' map 
logical memory addresses to physical memory loca- 
tions. The PMMU also contains three' 8-bit control 
registers for programming the PMMU, and nine 8-bit 
status registers to record information in the event of an 
access violation. 


Page Descriptor Registers 


The segment number and five most-significant bits of a 
logical address determine, by associative lookup, which 
page descriptor register is used in address translation. 
Each register also contains the necessary information to 
enable checking to ensure that the type of reference 
made is permitted. An indication that the segment has 
been previously read or written is also contained in the 
register. 


Each of the 64 page descriptor registers contains a 
12-bit logical address field, a 13-bit physical address 
field, and a 7-bit attribute field (Figure 3). 


Figure 3. Page Descriptor Register Format 


. The logical address field is used during the associative 
search phase of address translation; a match of this field 
with the most-significant bits of the logical address in- 
dicates that the descriptor is to be used during physical 
address generation. The physical address field supplies 
the most-significant bits of the generated physical ad- 
dress. 


The attribute field contains seven flags (Figure 4). Three 
flags protect the page against certain types of access, 
one indicates the special structure of the page, and two 


6 
0 


IVALIDI REF I CHG I 
DIRW I EXC I SYS I RD 1 


Figure 4. Attribute Field of Page Descriptor Register 
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encode the types of accesses that have been made to 
the page. The seventh flag is used to indicate whether or 
not the information in the descriptor is valid. A flag is set 
when its value is 1. During a write to only the attribute 
field, bit 7 of the byte is ignored. When an attribute field 
is read, bit 7 is undefined. When an entire descriptor is 
accessed, bit 7 will be part of the physical address field. 
The following descriptions explain how these flags are 
used. 


Valid (VALID). When this flag is set, the descriptor contains valid 
page information for the currently executing process. When this bit is 
clear, the logical address generated by the VMPU is not compared 
against the contents of the logical address field, so the descriptor is 
not used for address translation. Only descriptors that have this flag 
set are used during the associative search. 


Read·Only (RD). When this flag is set, the page is read·only and is 
protected against any write access. 


System·Only (SYS). When this flag is set, the page can be accessed 
only in System mode, and is protected against any access in Normal 
mode. 


Execute·Only (EX C). When this flag is set, the page can be accessed 
only during an Instruction Fetch cycle and is thus protected against ac· 
cess during other cycles. 


Direction and Warning (DIRW). When this flag is set, the page's 
memory locations are considered to be organized in descending order 
and each write to the page is checked for access to the lowest 128 
bytes. Such an access generates a Trap Request signal to warn of 
potential stack overflow, but neither an Abort Request nor a Suppress 
signal is generated . 


Changed (CHG). When this flag is set, the page has been changed 
(written into). This bit is set automatically during any write access to 
this page if the write access does not cause a violation. 


Referenced (REF). When this flag is set, the page has been referenc- 
ed (either read or written). This bit is set automatically during any ac- 
cess to the page if the access does not caus,e a violation. 


The byte format that is requIred to write into or read from 
an attribute field is shown in Figure 5. 


IVALIDI REF I 
CHG I 
DIRW I EXC I SYS I RD I 


Figure 5. Format of Byte for Reading or Writing 
a Descriptor's Attribute 
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Control Registers 


The three user-accessible, 8-bit control registers in the 
PMMU direct the functioning of the PMMU (Figure 6). 
The Mode register provides a sophisticated method for 
selectively enabling PMMUs in multiple-PMMU con- 
figurations. The Descriptor Address (DAR) register 
selects the particular page descriptor register to be ac- 
cessed during a control operation. The Descriptor Selec- 
tion Count (OSC) register pOints to the byte in the Page 
Descriptor register to be accessed during a control 
operation. 
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Figure 6. Control Registers 


Mode Register 


The Mode register contains a 3-bit identification (10) field 
that can distinguish up to eight enabled PMMUs in a 
multiple-PMMU configuration. This field is used during 
the Trap Request acknowledge sequence. In addition, 
the Mode register contains the following four flags: 


Multiple Page Table (MPT). This flag indicates whether more than 
one page table is present in the hardware configuration. When this flag 
is set, more than one table is present and the N/S line is used to deter- 
mine whether the PMMU contains the appropriate table. 


Normal Mode Select (NMS). This flag indicates whether the PMMU is 
to translate addresses when the N/S line is High or Low. If the MPT flag 
is set, the N/S line must match the NMS flag for the PMMU to translate 
addresses; otherwise, the PMMU address lines remain 3-stated. 


Translate (TRNS). This flag indicates whether the PMMU is to 
translate logical program addresses to physical memory locations or is 
to pass the logical addresses unchanged to the memory without pro- 
tection checking. In the Non-Translation mode, the most-significant 
output byte is the 7-bit segment number and the most-significant bit is 
O. When TRNS is set, the PMMU performs address translation and at- 
tribute checking. 


Master Enable (MSEN). This flag enables or disables the PMMU from 
performing its address translation and memory protection functions. 
When this flag is set, the PMMU performs these tasks; when the flag is 
clear the address lines of the PMMU remain 3-stated. 


Descriptor Address Register (DAR) 


This register pOints to one of the 64 page descriptor 
registers. Control commands to the PMM'U that access 
page descriptors implicitly use this pointer to select one 
of the page descriptor registers. The DAR has auto- 
incrementing capability so that multiple descriptors can 
be accessed in a block read/write fashion. 


Descriptor Selection Count (DSC) Register 


This register holds a 2-bit counter that indicates which 
byte in the descriptor is being accessed during Read or 
Write operations. A zero·in this counter indicates that the 
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highest-order byte of the descriptor is to be accessed 
(most-significant byte of the logical address field), a one 
indicates the next byte of the descriptor, a two indicates 
the third byte, and a three indicates the least-significant 
byte (containing the attribute field). 


Status Registers 


The following nine 8-bit status registers contain informa- 
tion useful in recovering from memory access violations 
(Figure 7): 
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Figure 7. Status Registers 
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Trap Type Register. This register describes the condi- 
tions that generate a Trap Request signal. 


Violation Segment Number and Violation Offset 
Registers. These three registers record the logical ad- 
dress that caused a Trap Request. 


Instruction Address Registers. These three registers 
record the logical address of the last instruction fetched 
before the first warning, access violation, or page fault. 


Bus Cycle Status Register. This register records the 
bus cycle status (status code, Read/Write operation and 
Normal/System mode). 


Read/Write Data Count Register. This register con- 
tains a 4-bit counter that counts the number of read and 
write data transactions whose addresses have been 
translated by the PMMU since the last instruction fetch 
. cycle. This ·count is locked when an Abort Request is 
generated, and indicates the number of successful data 
transactions performed by the aborted instruction. 
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Violation Type Register (VTR) Flags 


The VTR is used by the PMMU to determine the cause of 
a Trap Request. The PMMU generates a Trap Request 
when: it detects an access violation, such as an attempt 
to write into a read-only page; it detects a warning condi- 
tion, which is a write into the lowest 128 bytes of a page 
with the DIRW flag set; or no entry matches the logical 
address (a page fault). The .following seven flags are con- 
tained by the Violation Type register (VTR): 


Read-Only Violation (RDV). This flag is set when the VMPU attempts 
to access a read-only page and the RtW line is Low. 


System Violation (S YS V). This flag is set when the VMPU accesses a 
system-only page and the N/S line is High. 


Execute·Only Violation (EXCV). This flag is set when the VMPU at- 
tempts to access an execute-only page other than during an instruc- 
tion fetch cycle. 


ABORT, TRAP REQUEST, AND 
ACKNOWLEDGE· 


The PMMU generates a four-clock-cycle Abort Request 
(ABORT) when it detects an access violation or a page 
fault. This Signal on the ABORT (pin 33) and WAIT (pin 20) 
inputs of the VMPU inserts a five-cycle abort sequence 
that causes the VMPU to terminate instruction execu- 
tion. A Trap Request is generated when the PMMU 
detects an access violation, page fault, or write warning. 
This signal on the translation trap line of the VMPU (line 
14) causes the VMPU to generate a trap acknowledge 
after the instruction abortion (for an access violation or 
page fault) or after the execution of the instruction (for a 
write warning). In the case of an access violation or page 
fault, the PMMU also activates Suppress (SUP), which 
can be used by the memory to inhibit memory writes. 


Trap Request remains Low until a trap acknowledge is 
received (status = 0100). If a VMPU-generated violation 
occurs, Suppress is asserted for that memory reference. 
(If a Z8001 or Z8002 CPU generates the violation, any 
subsequent CPU memory reference also causes Sup- 
press.to be asserted until the end of the instruction.) In- 
tervening DMA accesses are not suppressed, however, 
unless they generate a violation. Violations detected dur- 
ing DMA accesses cause Suppress to be asserted for 
that access only; no Trap or Abort Requests are 
generated'during DMA accesses. 


Trap Requests to the VMPU are handled similarly to in- 
terrupts. To service a PMMU trap, the VMPU issues a 
trap acknowledge. The acknowledge is usually preceded 
by a dummy instruction fetch that is not used by the 
VMPU (the PMMU has been designed to ignore this dum- 
my fetch). During the identifier fetch of the acknowledge 
cycle, all enabled PMMUs use the Address/Data (AD) 
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Page Fault (PGFT). This flag is set when no logical address field of 
the valid descriptors in the PMMU matches the upper 12 bits of the 
logical address. 


Primary Write Warning (PWW). This flag is set when an access is 
made to the lowest 128 bytes of a page with the DIRW flag set. 


Secondary Write Warning (SWW). This flag is set when the VMPU 
writes data into the last 128 bytes of the system stack and EXCV, 
SYSV, PGFT, RDV, or PWW is set. With SWW set, subsequent write 
warnings for accessing the system stack do not generate a Trap Re- 
quest. 


Fatal Condition (FATL). This flag is set when any other flag in the 
Trap Type register is set and either a violation is detected or a write 
warning condition occurs in Normal mode. FATL is not set during a 
stack push in System mode that results in a warning condition. This 
flag indicates that a memory access error has occurred in the trap pro- 
cessing routine. Once set, no Trap Request or Abort Request signals 
are generated on subsequent violations. However, as long as the 
PMMU is enabled, Suppress signals are generated on this and subse- 
quent VMPU violations until the FATL flag is reset. . 


lines to indicate their status. A PMMU that has 
generated a Trap Request outputs a 1 on the AD line 
associated with the number in its 10 field; a PMMU that 
has not generated a trap request outputs a 0 on its 
associated AD line. AD lines with no associated PMMU 
remain 3-stated. During.a trap acknowledge, a PMMU 
uses AD line 8 + i if its ID field is i. 


Following the Acknowledge cycle, the VMPUautomati- 
cally pushes the program status onto the system stack 
and loads another program status from the trap vector at 
location 20H in the program status area. The PMMU's 
trap line is reset during the trap acknowledge. Suppress 
is not generated during the stack push. If the push opera- 
tion creates a write warning condition, a Trap Request is 
generated and serviced at the end of the context swap. 
The SWW flag is also set. Servicing this second Trap Re- 
quest also creates a write warning condition, but 
because the SWW flag is set, no Trap Request is 
generated. If a violation or page fault rather than a write 
warning occurs during the context swap, the FATL flag is 
set rather than the SWW flag. Subsequent violations or 
faults cause Suppress but not Trap Request to be 
asserted. Without the SWW and FATL flags, trap pro- 
cessing routines that generate memory violations or 
faults would repeatedly be interrupted and called to pro- 
cess the trap they created. 


The VMPU routine to process a Trap Request should first 
check the FATL flag to determine if a fatal system error 
has occurred. If not, the SWW flag should be checked to 
. determine· if more memory is required for the system 
stack. Finally, the trap itself should be processed and the 
Trap Type register reset. 


MULTIPLE PMMUs 


Although only one PMMU should be actively translating 
addresses at a given time, PMMU architecture directly 
supports various methods for multiple PMMU configura- 
tions. The following four examples illustrate different 
ways that PMMUs can be used to implement memory 
management systems capable of handling more than 64 
pages. 


Example 1. The first approach extends the capability of 
one PMMU for handling 64 pages to a multiple-PMMU 
configuration that manages more than 64 pages. The 
Chip Enable line is used to select a particular PMMU to 
translate a page address. For example, if one PMMU is 
assigned only pages for logical addresses whose bit 
number 11 is a 0 and another PMMU is assigned those 
whose bit number 11 is a 1, then the state of output line 
AD11 can be used to select the appropriate PMMU to 
translate a logical address. 


Example 2. Another way of using Chip Enable sepa~ 
rates program pages from data pages. One PMMU is 


CHANGING PAGE SIZE 


The PMMU directly supports pages of 2048 bytes in 
length. However, the addition of external circuitry 
enables the PMMU to support systems with larger or 
smaller pages. The following examples illustrate the 
technique for changing the supported page size. 


Example 1. To implement 4096-byte pages, address bit 
AD11 is not used in the translation process but is used 
directly as the most significant bit of the address loca- 
tion within a selected 4096-byte page. This can be 
achieved by doing the following: (1) set the AD11 input to 
be equal to the logical OR of the ST 3 and AD11 output 
lines of the VMPU, (2) require that the least significant bit 


DMA OPERATION 


At the start of a DMA cycle, DMASYNC must go Low 
whether or not the PMMU is used to translate DMA ad- 
dresses, to indicate the beginning of a DMA cycle. When 
DMASYNC has been Low for two cycles, the PMMU· 
assumes that a DMA device has control of the bus. A 
Low on DMASYNC inhibits the PMMU from using an in- 
determinate segment number on lines SNo-SNs. When 
the DMA logical memory address is valid, the DMASYNC 
line must be High on a rising edge of the, clock and then 
be Low by the next falling clock edge. The PMMU then 
performs its address translation and access protection 
functions during the clock period begun in this 
DMASYNC pulse. Upon the release of the bus at the ter- 
mination of the DMA cycle, the DMASYNC line must go 
High. After two clock cycles of DMASYNC High, the 
PMMU assumes that the VMPU has control of the bus 
and that subsequent memory references are VMPU ac- 
cesses. The first memory reference occurs at least two 
cycles after the VMPU regains control of the bus. During 


associated with translating addresses generated during 
instruction fetches (status codes 1100 and 1101) and the 
other with addresses generated during data fetches 
(status codes 1000, 1001, 1010, 1011, and 1111). Chip 
Enable for each PMMU is obtained from the status code 
(Le., status lines STo-ST3). 


Example 3. Several PMMUs can be used to implement 
multiple translation tables. Multiple tables reduce the 
time required to switch tasks by assigning separate 
tables to each task. Multiple translation tables for multi- 
task environments can use the Master Enable flag to 
enable the appropriate PMMUs through software. 


Example 4. A final method uses two translation tables 
to separate system from normal memory. The MPT and 
NMS flags in the Mode register can be used in conjunc- 
tion with the N/S line to select the PMMU that contains 
the appropriate table. 


in the logical address field of each descriptor register be 
set to 1, and (3) use the logical address bit AD11 output 
by the VMPU instead of the physical address A11 output 
by the PMMU. The AD11 input must be 1 during address 
translation but must equal the AD11 output by the CPU 
during command cycles to the PMMU; ST3 is used to 
distinguish the two types of transactions. 


Example 2. To implement 1024-byte pages an addi- 
tional address bit' must be translated. Two PMMUs are 
used. The CE input is driven by AD10 for one PMMU and 
its complement, AD1O, for the other. 


VMPU cycles, DMASYNC should remain High. Refer to 
the paragraph "Memory Read and Write" and Figure 8 
for further information. 


Direct memory access (DMA) operations can occur be- 
tween instruction cycles and can be handled through the 
PMMU. The PMMU permits DMA in either the System or 
Normal mode of operation. For each memory access, 
the page attributes are checked, and if a violation is 
detected, 
Suppress 
is 
activated. 
DMA violations 
generate a Suppress only on a per-memory-access 
basis. 
I 


The DMA device should note the Suppress signal and 
record sufficient information to enable the system to 
recover from the access violation. Neither a Trap Re- 
quest nor an Abort Request is ever generated during a 
DMA operation, therefore warning conditions are not 
signaled. 
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PMMU COMMANDS 


The various registers in the PMMU can be read and writ- 
ten using VMPU Special I/O commands. The machine 
cycles of these commands cause the status lines to in- 
dicate that a special input/output operation is in pro- 
gress. During these machine cycles, the PMMU enters 
the command mode. In this mode, the rising edge of AS 
indicates that a command is present on lines ADa-AD15' 
If this command indicates that data is to be written into 
one of the PMMU registers, the data is read from lines 
ADa-AD15 while DS is Low. If the command indicates 
that data is to be read from one of the PMM!:!..!egisters, 
the data is placed on lines ADa-AD15 while DS is Low. 


There are five commands that read or write various 
fields in the page descriptor register. The status of the 
read/write line indicates whether the command is a read 
or a write. 


The autoincrementing feature of the Descriptor Address 
Register (DAR) can be used to block load page descrip- 
tors using the repeat forms of the Special I/O instru~­ 
tions. The DAR is autoincremented at the end of the 
field. The command acc~ssing the entire page descrip- 
tor register references the fields in the order of logical 
address, physical address, and attribute; four bytes are 
written in succession. 


Table 1 gives the five commands that are used to write 
data into descriptor fields. 


Table 1. Descriptor Field Write Commands 


Opcode 


(Hex) 
Instruction 


OA 
ReadlWrite Attribute field 


OB 
ReadlWrite Descriptor (all fields) 


OE 
ReadlWrite Attribute field; increment DAR 


OF 
ReadlWrite Descriptor (all fields); increment 
DAR 


15 
Reset all Valid Attribute flags 


USE OF THE PMMU WITH OTHER 
Z8000 CPUs 


The PMMU is designed to operate in conjunction with 
the Z8003 VMPU; however, it can also be used with 
other CPUs in the Z8000 Family. The following examples 
suggest simple system configurations; more sophisticat- 
ed arrangements are possible. 


The Z8004 VMPU generates nonsegmented 16-bit ad- 
dresses only. The PMMU can be used to implement a 
paged virtual memory by tying the segment number in- 
puts of the PMMU to 0 and requiring the most'significant 
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Table 2 gives the three commands that are used to read 
and write the control registers. 


Table 2. Control Registers' Read/Write Commands 


Opcode 


(Hex) 
Instruction 


00 
ReadlWrite Mode register 


01 
ReadlWrite Descriptor Address register 


20 
ReadlWrite Descriptor Selector Count register 


The status registers are read-only registers, although the 
Trap Type Register (ITR) can be reset. Twelve instruc- 
tions, shown in Table 3, access these registers. 


Table 3. 'Status Registers' Access Instructions 


Opcode 


(Hex) 
Instruction 


02 
Read Trap Type register 


03 
Read Violation Segment Number register 


04 
Read Violation Offset (high-byte) register 


05 
Read Bus Status register 


06 
Read Instruction Segment Number register 


07 
Read Instruction Offset (high-byte) register 


11 


13 


14 


21 


22 
23 


Reset Trap Type register 


Reset SWW flag in VTR 


Reset FATL flag in VTR 


Read Violation, Offset (low-byte) register 


Read ReadlWrite Data Counter register 


Read Instruction Offset (low-byte) register 


seven bits of the logical address field to be O. Since the 
Z8004 VMPU lacks a translation trap request input pin, 
the nonmaskable (or other interrupt request) pin should 
be used instead. 


The PMMU extends the physical addressing capability of 
the Z8004 without using the segmentation mechanism of 
the Z8003. This use is similar to the way in which 16-bit 
minicomputers extend their addressing capability. 


The Z8001 and Z8002 CPUs do not support the instruc- 
tionabort mechanism. A page fault for one of these 
CPUs is, in general, non-recoverable, since during an in- 
terrupt, the current instruction runs to completion, 
possibly overwriting CPU registers. For the nonseg- 
mented Z8002, this means that all pages that the CPU 
can access must be in physical memory and appropriate 
information must be in the PMMU page descriptor 


PMMU TIMING 


The PMMU translates addresses and checks for access 
violations by stepping through sequences of basic clock 
cycles corresponding to the cycle structure of the 
VMPU. Timing diagrams that show the relative timing 
relationships of PMMU signals during the basic opera- 
tions of memory read/write and PMMU control com- 
mands are given in this section. 


Memory Read and Write 


Memory read and instruction fetch cycles are identical, 
except for the status information on the STo-ST 3 inputs. 
During a memory read cycle (Figure 8), the 7-bit seg- 
ment number is input on SNo-SNs one clock period 
before the address offset; a High on DMASYNC during 
T3 indicates that the segment offset data is valid. The ad- 
dr'ess offsets are placed on the ADo-AD15 inputs early in 
the first clock period. Valid address offset data is in- 
dicated by the rising edge of AS. Status, mode, and chip 
enable information becomes valid early in the memory 
access cycle and must remain stable throughout. The 
most significant 16 bits of the address (physical memory 
location) remain valid until the end of T3. Abort Request, 
Trap Request, and Suppress are asserted in T2 (Figure 
9). Abort Request is asserted for four clock cycles. Trap 
Request 
remains 
Low 
until 
trap 
acknowledge 
(status = 0100) is received. Suppress is asserted during 
the current machine cycle and terminates during T3. 


PMMU Command Cycle 


During the command cycle of the PMMU (Figure 11), 
commands are placed on lines ADs':'AD15 during T1. The 
status lines indicate that a Special I/O instruction is in 
progress, and the CS line enables the appropriate PMMU 
for that command. Data to be written to a register in the 
PMMU must be valid on lines ADs-AD15 late in T2. Data 
read from the PMMU is placed on lines ADs-AD15 late in 
the TWA cycle. 


Input/Output and Refresh 


Input/output and refresh operations are indicated by 
codes on status lines STo-ST3' During these operations, 
the PMMU refrains from any address translation or pro- 
tection checking. Lines Aa-A23 remain 3-stated during 
these operations. 


Reset 


The PMMU can be reset by either hardware or software 
mechanisms. A hardware reset occurs on the falling 


registers. For the segmented Z8001 , this means that pro- 
grams must explicitly request segments before access- 
ing them and must free segments after use. It also 
means that segments are allocated in units of the page 
size and that limit protection is performed with this 
granularity. Use of the PMMU with the Z8001 and Z8002 
CPUs permits a paged allocation of main memory and 
extends the physical address capability of the Z8002. 


edge of the Reset signal; a software reset is performed 
by a VMPU special I/O command. A hardware reset 
clears the Mode register, Trap Type Register, and 
Descriptor Selection Count register. If the CS line is Low, 
the Master Enable flag in the Mode register is set to 1. All 
other registers are undefined. After reset, 
lines 
ADo-AD15 and Aa-A23 are 3-stated. The SUP and 
ABORT open-drain outputs are not driven. If the Master 
Enable flag is not set during reset, the PMMU does not 
respond to subsequent addresses on its AD lines. To 
enable a PMMU after a hardware reset, a PMMU com- 
mand must be used in conjunction with CS. 


A software res!3t occurs when the Reset Violation Type 
Register command is issue~:L This command clears the 
Trap Type Register and returns the PMMU to its initial 
state (as if no violations or warnings had occurred). Note 
that the hardware and software resets have different ef- 
fects. 


Abort, Trap Request, and Aclmowledge 


The PMMU generates a Trap Request whenever it fails to 
find a page entry corresponding to the logical address 
(that is, a page fault), detects an access violation, or 
detects a write into the lowest 128-byte block of a page 
. with the DIRW flag set (Figure 12). In the case of an ac- 
cess violation or page fault, the PMMU also activates 
Suppress and Abort Request. The Suppress Signal is us- 
ed by memory to inhibit memory writes. The Trap Re- 
quest remains Low until a trap acknowledge signal 
(status = 0100) is received. Violations detected during 
DMA cycles cause Suppress to be asserted during that 
cycle only, but no Trap Request is generated. 


When the PMMU issues a Trap Request, it awaits the in- 
dication of' a trap acknowledge. Subsequent violations 
occurring before the trap acknowledge indication is 
received are detected and appropriately processed. Dur- 
ing a Trap Acknowledge cycle, the PMMU drives one of 
its Address/Data lines; the selection of the line is a func- 
tion of the identification field of the Mode register. After 
the Trap Request has been acknowledged by the VMPU, 
the Violation Status register should be read by a special 
I/O command in order to determine the cause of the trap. 
The Trap Type register should be reset so that subse- 
quent traps are recorded correctly. 


225 


226 


CLK 


NIS, 


STo-ST3 


SNo-SN6 


DMASYNC 


ADa-AD15 


RIW 


TN 


- 
I 


/ 


/ 


T1 
T2 
T3 


I 
I 
I 


SEGMENT NUMBER 
DON'T CARE 


\ 
/ 


J 
ADDRESS VALID 
, 


\ 


( 
> 


, 


MEMORY ADDRESS 
)--- 
DATA IN 


I 


/ 
L 


Figure 8. Memory Read Timing 


2081-009 


eLK 


AS 


AD 


2081-010 


'ir 
ALLOW MORE WAIT STATES 


T1 
T2 
TWA 
TWA 
TWA 
TWA 
TWA 
T3 
T1 
flJL 
\J 


, 
. f~ 


=>DC 
~XJOC 


"'~----------------------------~--------~/)' 


"'~--------------------------------------~'f 
\ ____ 
~r/ 


Figure 9. Abort and Trap Request Timing 


DEASSERTED 
fiN TRAPACK 


227 


228 


eLK 


NIS, 
STO-ST3 


SNo-SN6 


DMASYHC 


ADa-AD 15 


R/W 


TN 


- 
I 


/ 


T1 
T2 
T3 


I 
I 
I 


SEGMENT NUMBER 
DON'T CARE 


\ 
/ 


J 
ADDRESS VALID 
)- 
, 


\ 


MEMORY ADDRESS 
DATA OUT 


L 


Figure 10. Memory Write Ti~lng 


2081-011 


Tj 
T2 
TWA 
T3 


II 
• 


CLOCK 
I 
I 
I 
I 
- 


CS 


-=x 
STO-ST3 - 
- ---------~------- -------- -------- .. ---- 


HIS 
LOW 


- 1\ 
AS 


- ex 
c 


'- 


ADa-AD15 
COMMAND VALID 
}- - 
- 
- 
- -- 
DATA IN 
- 
I 


INPUT ~ 
DS 


R/v.; J 
L 
, 
- 


, 


- =x 


ADa-AD15 
COMMAND VALID 
DATA OUT 
- 


OUTPUT < 
OS 


- r\ 
r 


R/v.; 
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SIGNAL DESCRIPTIONS 


The 28015 is produced in a 64-pin package; the func- 
tions performed by the device's input and/or output pins 
are shown in Figure 13. Pin/signal name assignments 
are shown in Figure 14. The device sig'nal names 
together with a brief description of the function(s) per- 
formed by each are given in the foJlowing paragraphs. 


Aa-A23. Address 
Bus 
(out'puts, 
active 
High, 
3-state). These address lines are.the16 most significant 
bits of the physical memory location. 


ABORT. Abort Request (output, active low, open 
drain). A low on this line indicates MMU requests for an 
instruction abort. This line is enabled when a page fault 
or access violation is detected. 


AOO-A015. Address/Data Bus (inputs/outputs, active 
High, 3-state). ADo-AD? are used for addresses and in- 
puts only. They carry the low-order byte in the offset of 
logical addresses intended for translation. ADa-AD15 
are multiplexed address and data lines that are used 
both for the eight most significant bits of the logical ad- 
dress and for commands. 
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. AS. Address Strobe (input, active low). The rising edge 
of A8 indicates that lines ADo-AD15, 8To-8T3, R/W, CE, 
and Nis are valid. 


CEo Chip Enable (input, active low). This line selects a 
PiviiviU to translate a logical address. 


ClK. System Clock (input). ClK is a + 5 V single- 
phase, time-base input used for both the VMPU and 
PMMU. 


CS. Chip Select (input, active low). This line selects a 
PMMU for a control command. 


OMASYNC. DMA/Segment Number Synchronization 
Strobe (input, active High). A low on this line indicates a 
DMA access is occurring; a High indicates the segment 
number is valid. It must be High during VMPU cycles and 
low when 8N lines are 3-stated. 


OS. Data Strobe (input, active low). This line provides 
timing for the data transfer between the PMMU and the 
28003 VMPU. 


2081-013 


N/S. Normal/System 
Mode 
(input, 
Low = System 
mode). N/S indicates to the PMMU that the VMPU or 
DMA is in the Normal or System mode. 


RESET. Reset (input,- active Low). A Low on this line 
resets the PMMU. 


R/W. Read/Write (input, Low = write). R/Windicates 
whether the VMPU is reading from or writing to either 
memory or the PMMU. 


SNo-SNs. Segment Number (inputs, active High). 
These lines provide the 7~bit segment number of a logi- 
cal address. 


STo-ST3. Status (inputs, active High). These lines 
(Table 4) specify the status of the associated VMPU. 


SUP. Suppress (output, active Low, open-drain). This 
signal is asserted during the current bus cycle when a 
page fault or any access violation, except write warning, 
occurs. 


TRAP. Trap 
Request (output, 
active 
Low, 
open- 


drain). The PMMU interrupts the VMPU with a Low on 
this line when the PMMU detects a page fault, access 
violation, or write warning. 
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Table 4. Status Lines 


Definition 


Internal operation 


Memory refresh 


1/0 reference 


Special 1/0 reference (for example, to a 


PMMU) 


Translation trap acknowledge 


Nonmaskable interrupt acknowledge 


Nonvectored interrupt acknowledge 


Vectored interrupt acknowledge 


Data memory request 


Stack memory request 


Data memory request (External Processing 
Architectu re) 


Stack memory request (External Processing 


Architecture) 


Instruction space access 


Instruction fetch, first word 


External Processing Unit-CPU transfer 


Bus lock, data memory request 
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Figure 14. Pin ASSignments 
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AC CHARACTERISTICS 


The following composite timing diagram shows the AC 
timing relationships of the PMMU's control, address, and 
data signals. The ac characteristics of these signal rela- 
tionships are described in the AC Characteristics Table. 


AC CHARACTERISTICS TABLE' 


Min 
Max 


No_ Symbol 
Parameters 
(4 MHz) 
(4 MHz) 
Notes 


1 TcC 
Clock Cycle Time 
250 
2 TwCh 
CJock Width (High) 
105 
3 TwCI 
Clock Width (low) 
105 
4 TfC 
Clock Fall Time 
20 
5 TrC 
Clock Rise Time 
20 
6 TdDSA(RDv) -- OS ! (Acknowledge) to Read Data Valid Delay 
100 
1-- 
7 TdDSA(RDD 
OS t (Acknowledge) to Read Data Float Delay 
20 
75 
8 TdDSR(RDv) 
OS I (Read) to AD Output Driven Delay 
100 
9 TdDSR(RDf) 
OS t (Read) to Read Data Float Delay 
20 
75 
10 TdC(WDv) 
ClK t to Write Data Valid Delay 
160 
11 ThC(WDn) 
ClK.! to Write Data Not Valid Hold Time 
30 
12 TwAS' 
Address Strobe Width 
60 
13 TsOFF(AS) 
Offset Valid to AS t Setup Time 
45 
14 ThAS(OFFn) 
AS t to Offset Not Valid Hold Time 
60 
15 TdAS(C) 
AS I to ClK t Delay 
110 
16 TdDS(AS) 
OS t to AS ! Delay 
50 
17 TdAS(DS) 
AS t to OS I Delay 
50 
18 TsSN(C) --- SN Data Valid to ClK t Setup Time 
120 
19 ThC(SNn) 
ClK t to SN Data Not Valid Hold Time 
0 
20 TdDMAS(C) 
DMASYNC Valid to ClK t Delay 
120 
21 TdSTNR(AS) 
Status (STo-ST3, NiS, R/W) Valid to 'AS t Delay 
60 
22 TdC(DMA) 
ClK t to DMASYNC ! Delay 
20 
23 TdST(C) 
Status (STo-ST3) Valid to ClK t Setup Time 
140 
24 TdDS(STn)--DS t to Status Not Valid Delay 
0 
25 TdOFF(Av) 
Offset Valid to Address Output Valid Delay 
200 
26 TdST(Ad) 
Status Valid to Address Output Driven Delay 
180 
27 TdDS(Af) 
OS t to Address Output Float Delay 
30 
160 
28 TdAS(Ad) 
AS ! to Address Output Driven Delay 
170 
29 TdC(Av) 
ClK ! to Address Output Valid Delay 
155 
30 TdAS(TRAP) --AS t to TRAP I Delay 
110 
1,2-- 
31 TdC(TRAP) 
ClK t to TRAP t Delay 
300 
1,2 
32 TdAS(SUP) 
AS t to SUP! Delay 
115 
1,2 
33 TdDS(SUP) 
OS t to SUP t Delay 
30 
155 
1,2 
34 TsCS(AS) 
Chip Select Input Valid to AS t Setup Time 
10 
35 ThAS(CSn) 
AS t to Chip Select Input Not Valid Hold Time 
80 
36 TdAS(C) 
AS t to ClK t Delay 
0 
37 TsCS(RST) 
Chip Select Input Valid to RESET t Setup Time 
150 
38 ThRST(CSn) 
RESET t to Chip Select Input Not Valid Hold Time 
0 
39 TwRSTI 
RESET Width (low) 
2TcC 
40 TdC(RDv) 
ClK t to Read Data Valid Delay 
460 
41 
TdDS(C) 
OS t to ClK t Delay 
30 
42 TdC(DS)--- ClK I to OS t Delay 
0 
110 
43 TdAS(ABORT) 
AS t to ABORT I Delay 
110 
44 TdC(ABORT) 
ClK ! to ABORT t Delay 
30 
155 
45 TdCE(Av) 
CEI to Address Output Valid Delay 
235 
46 TsCE(AS) 
CE ! to AS t Setup Time 
0 
47 ThAS(CEn) 
AS t to Chip Enable Input Not Valid Hold Time 
60 


NOTES: 
1. 50 pF load. 
2. 2.2K pull·up. 
3. All times given in nanoseconds (ns). 
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ABSOLUTE MAXIMUM RATINGS 


Voltages on all inputs and outputs 
with respect to GND ............... -0.3 V to + 7.0 V 


Operating Ambient 
Temperature ....................... O°C to + 70°C 


Storage Temperature ............. -65°C to + 150 °C 


STANDARD TEST CONDITIONS 


The following dc characteristics apply for the given stan· 
dard test conditions unless otherwise noted. All voltages 
are referenced to GND. Positive current flows into the 
referenced pin. Standard conditions are as follows: 


m +4.75 V::5 Vee::5 +5.25 V 
m GND = 0 V 
m O°C::5 TA::5 + 70°C 


DC CHARACTERISTICS 


Symbol 
Parametor 


VCH 
Clock Input High Voltage 


VCl 
Clock Input Low Voltage 


VIH 
Input High Voltage 


VIL 
Input Low Voltage 


VOH 
Output High Voltage 


VOL 
Output Low Voltage 


III 
Input Leakage 


IOl 
Output Leakage 


ICC 
Vcc Supply Current 


ORDERiNG iNFORMATiON 


Temperature 


Min 


Vcc-O.4 


-0.3 


2.0 


-0.3 


2.4 


Stresses greater than those listed under Absolute Maximum Ratings 
may cause permanent damage to the device. This is a stress rating 
only; operation of the device at any condition above those indicated in 
the operational sections of these specifications is not implied. Ex· 
posure to absolute maximum rating conditions for extended periods 
may affect device reliability. 


The type of test circuit used is as follows: 


Max 
Unit 


Vcc+ 0.3 
V 


0.45 
V 


VCC+ 0.3 
V 


0.8 
V 


V 


0.4 
V 


±10 
/LA 


±10 
p.A 


300 
mA 


+5V 


2.2K 


Figure 15. Test Load Circuit 


Condition 


Driven by External Clock Generator 


Driven by External Clock Generator 


IOH = -250 p.A 


IOl = +2.0 mA 


0.4 s VIN s +2.4 V 


0.4 s VIN s +2.4 V 


Product 
Number 
Package 
Range 
Speed 
Description 


Z8015 
Ceramic 
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O°C to + 70°C 
4 MHz 
Paged Memory 
Management Unit 
(Z·PMMU),64·pin 


2081·016 00·2081-03 


Zilog 


FEATURES 


• Memory-to-peripheral transfers up to 2.66M bytes per 
second at 4 MHz. 


[J Memory-to-memory transfers up to 1.33M bytes per 
second at 4 MHz. 


II Two fully independent, multi-function channels. 


III Masked data pattern matching for Search and 
Transfer-and-Search operations. 


D Funneling option that permits mixing of byte and word 
data during transfer operations. 


GENERAL DESCRIPTION 


The Z8016 DMA Transfer Controller (DTC) is a high per- 
formance data transfer device designed to match the 
power and addressing capability of the Z8000 CPUs. In 
addition to providing block data transfer capability be- 
tween memory and peripherals, each of the two DTC 
channels can 
pe~form peripheral-to-peripheral and 
memory-to-memory transfers. A special Search mode of 
operation compares data read 
from memory or 
peripherals with the contents of a pattern register. A 
search can be performed concurrently with transfers or 
as an operation in itself. 


, In all operations (Search, Transfer, and Transfer-and- 
Search), the DTC can operate in either Flowthrough or 
Flyby transfer mode. In the Flowthrough mode, data is 
stored temporarily within the DTC on its way from source 
to destination. In this mode transfers can be made be- 
tween a word-oriented memory and a byte-oriented 
peripheral through the bidirectioQal byte/word funneling 
option. In Flyby mode, data is transferred in a single step 
(from source to destination), thus providing twice the 
throughput. 
. 
, 


The Z8016 DTC takes full advantage of the Z8000 
memory management scheme by interfacing directly to 
the Z8010' Memory Management Unit (MMU) or the 
Z8015 Paged Memory Management Unit (PMMU). In this 
c.onfiguration, 8M bytes of logical address range are pro- 
Vided for each CPU address space. Alternatively, the 
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[J Can operate in logica-I address space with Zilog 
Memory Management Units, providing an 8M byte 
logical addressing range and 16M byte physical ad- 
dressing range., 


[J Programmable chaining operation provides automatic 
loading of control parameters from memory into each 
channel. 


[J Software- or hardware-controlled W~it state insertion. 


[J Z-BUSTM daisy-chain interrupt hierarchy and bus- 


request structure. 


Z8016 DTC can operate independently of an MMU 
directly addressing up to 16M bytes of physical addres~ 
space. 


In addition to providing a hardware WAIT input to accom- ' 
modate different memory or peripheral speeds, the 
Z8016 DTC allows the user to program the automatic in- 
sertion of either zero, one, two, or four Wait states for 
either source or destination addresses. Alternatively, the 
WAIT input pin function can be disabled and these 
software-programmed Wait states used exclusively. 


The Z8016 DTC minimizes CPU involvement by allowing 
each channel to load its control registers from memory 
automatically when a DMA operation is complete. By 
loading the address of the next block of control 
parameters as part of this operation, command chaining 
is accomplished. The/only action required of the CPU is 
to load the address of the control parameter table into 
the channel's Chain Address register and then issue a 
Start Chain command. 


In some DMA applications, data is transferred con- 
tinuously between the same two locations; To service 


t~ese repetitive DMA operations, base registers are pro- 
Vided on each channel to reinitialize the current source 
and destination address registers. This re-initialization 
eliminates the need for reloading registers from memory 
tables. 
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The ZS016 DTG is directly Z-BUS compatible, and 
operates within the ZSOOO daisy-chain vectored-priority 
interrupt scheme. The Demand Interleave operation 
allows the DTG to surrender the bus to the external 
system, or to alternate between internal channels. This 
capability allows for parallel operations between dual 
channels or between a DTG channel and the GPU. 


The DTG can be used to provide a central DMA function 


SEGMENT 
NUMBER 


SNo 


SN1 


SN2 


SN3 


SN4 


SNs 


SN6 


ADo 


AD1 


AD2 


AD3 


AD4 


ADs 


AD6 


for the GPU or to provide dispersed DMA operations in 
conjunction with a wide variety of ZSOOO Family 
peripheral controllers. 


The ZS016 DTG is packaged in a 4S-pin DIP and uses a 
single + 5 V power supply. 


The ZS016 DTG pin functions and assignments are 
shown in Figures 1 and 2, respectively. 
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47 
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46 
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Figure 1. Pin Functions 


SIGNAL DESCRIPTIONS 


ADo-AD1s. Address/Data Bus (bidirectional, active 
High, 3-state) pins 5-20. These multiplexed Ad- 
dress/Data lines are used for all I/O and memory trans- 
actions. 


AS. Address Strobe (bidirectional, active Low, 3-state) 
pin 44. When the DTG is bus master the rising edge 'of AS' 
(while OS is High) indicates that addresses are valid .. 
When the DTG is not bus master, the address lines are 
sampled on the rising edge of AS. There are no timing re- 
quirements between AS as an input and the DTG clock, 
because the Z-BUS does not use a bused clock. If AS 
and OS are simultaneously Low, the DTG will be reset. 
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Figure 2. Pin Assignments 


BAl. Bus Acknow/edge In (input, active Low) pin 1. 
Signals that the bus has been released for DTG control. 
In multiple-DTG configurations, the BAI pin of the 
highest-priority DTG is normally connected to the Bus 
Acknowledge pin of the GPU. Each lower-priority DTG 
has its BAI connected to the BAO of the next higher- 
priority DTG. 


BAO. Bus Acknowledge Out (output, active Low) pin 3. In 
a multiple-DMA configuration, this pin signals that no 
higher-priority DTG has requested the bus. BAI and BAO 
form a. daisy .chain for multiple- DTG priority resolution. 


2129-001,002 . 


BUSREQ. Bus Request (bidirectional, active Low, open- 
drain) pin 2. BUSREO is used by the DTC to obtain con- 
trol of the bus from the CPU. Beforadriving BUSREO ac- 
tive, the DTC samples this line to ensure that another re- 
quest is not already being made by another device. 
Since the DTC internally synchronizes the sampled 
BUSREO signal, transitions on BUSREO can be asyn- 
chronous with respect to the DTC clock. 


B/W. Byte/Word (output, 3-state) pin 35. This output in- 
dicates the type of data transferred on the AddressIData 
(AID) bus. A High on this line indicates a byte (S-bit) 
transfer and a Low indicates a word (16-bit) transfer. This 
Signal is activated when AS goes Low and remains valid 
for the duration of the transaction. 


ClK. DTC Clock (input) pin 45. The Clock signal controls 
internal operations and the rates of data transfer. It is 
usually derived from a master system clock or an 
associated CPU clock. When the DTC is used with an 
MMU, both must be driven from the same clock signal. 
While many DTC input Signals are asynchronous, transi- 
tions for other signals (such as WAIT inputs) must meet 
setup and hold requirements relative to the DTC clock. 
(See the timing diagrams for details.) 


CS/WAIT. Chip Select/Wait (input, active Low) pin 42. 
When the DTC is not in control of the system bus, this pin 
serves as a Chip Select (CS) input. A CPU or other exter- 
nal device uses CS to activate the DTC for reading and 
writing the DTC's internal registers. (CS can be held Low 
for multiple transfers to and from the DTC, provided that 
AS and OS are enabled for each transfer.) There are no 
timing requirements between the CS input and the DTC 
clock; the CS input timing requirements a're only defined 
relative to AS. 


When the DTC is in control of the system bus, this pin 
serves as the WAIT input. Slow memories and peripheral 
devices can use WAIT to extend OS during bus transfers. 
Unlike the CS input, transitions on the WAIT input must 
meet certain timing requirements relative to the DTC 
clock (see the Active State timing diagram for details). 
The WAIT fU~lction can be disabled using a control bit in 
the Master Mode register, in which case this input is 
treated as a Chip Select only and is ignored when the 
DTC is in control of the system bus. 


OACK1, OACK2. DMA Acknowledge (output, active Low) 
pins 39 and 40. There is one DMA Acknowledge line 
associated with each channel. The DACK lines are pro- 
grammed in the Channel Made register to be pulsed, 
held active, or held inactive during DMA transfers. Dur- 
ing Flyby operations the DACK line is used for two pur- 
poses. It selects the peripheral involved in the transfer, 
and it provides timing information on when to access the 
bus. During flowthrough operations the DACK line can 
be programmed to be active or inactive during a DMA 
transfer. DACK is not output during chaining operations. 


OREQ1, OREQ2. DMA Request (input, active Low) pins 
36 and 37. There is aDMA Request line associated with 
each channel. These lines can make transitions indepen- 
dent of the DTC clock. Theyare used by external logic to 
initiate and control DMA operations performed by the 
DTC. 


OS. Data Strobe (bidirectional, active Low, 3-state) pin 
43. A Low on this signal while AS is High indicates that 
the AID bus is being used to transfer data. When the CPU 
is bus master and is transferring information to or from 
the DTC, OS is a timing input used by the DTC to move 
data to or from the AID bus. 


EOP. End of Process (bidirectional, active Low, open- 
drain, asynchronOus) pin 3S. This line is output when a 
Terminal Count (TC) or Match Condition (MC) termination 
occurs (see Termination section). An external source 
can terminate a DMA operation in progress by driving 
EOP Low. EOP always applies to the active channel; if no 
channel is active, EOP is ignored. The Suppress output 
of the MMU can be connected to EOP to terminate DMA 
accesses that violate the MMU protection settings. To 
provide full access protection, an external EOP is ac- 
cepted even during chaining. 


lEI. Interrupt Enable In (input, active High) pin 46. lEI is 
used with lEO to form an interrupt daisy chain when 
there is more than one interrupt-driven device. A High 
lEI indicates that no other higher-priority device has an 
interrupt under service or is requesting an interrupt. 


lEO. Interrupt Enable Out (output, active High) pin 4S. 
lEO is High only if lEI is High and the CPU is not servic- 
ing an interrupt from the requesting DTC. lEO is con- 
nected to the next lower-priority device's lEI input and 
thus inhibits interrupts from lower-priority devices. 


INT. Interrupt Request (output, open-drain, active Low) 
pin 47. This signal is pulled Low when the DTC requests 
an interrupt. 


N/S. Normal/System (output, 3-state) pin 30. The N/S 
signal is activated when the DTC is bus master. The N/S 
signal indicates which memory space is being accessed 
by going High for normal memory and Low for system 
memory. 


R/W. Read/Write (bidirectional, 3-state, Low = write) pin 
41. When the DTC is not bus master, R/W is a status in- 
put used to indicate whether data is being read from 
(H igh) or written to (Low) the DTC. When the DTC is bus 
master, R/W is an output used to indicate whether the 
DTC is reading or writing the addressed location. During 
Flyby DMA operations, the "Flyby peripheral" (Figure 3) 
inverts the R/W signal to determine whether it must read 
or write. 
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5No-5N6. Segment Number (output, 3-state) pins 21-25 
and 28-29. In logical address configuration, these lines 
provide the segment number field of a 23-bit segmented 
address. The SNo-SN6 110 address information can be 
use'd to increase the DTC's logical 110 address space 
beyond that of the CPU. In physical address configura- 
tion, these lines provide bits 23 through 17 of a 24-bit 
linear address. The 24th bit (MSB) is output on SN7/MMU 
Sync. 


SN7 or MMU Sync. Segment Number 7 orjAMU Sync 
(output, 3-state) pin 27. In a logical address space con- 
figuration (with MMU), this line outputs an active High 
pulse prior to each machine cycle. The MMU uses this 
signal to synchronize access to its translation table and 
to differentiate between CPU and DTC control. The MMU 
ignores MMUSYNC if the status lines (STo-ST3) indicate 


that an 110 transaction is being performed. This output is 
Low when the DTC is not bus master and the MM1 bit in 
the Master Mode register is set. 


In a physical' address space configuration (without 
MMU), this line outputs SN7, which becomes the 24th 
address bit in a linear address space. The 24-bit linear 
address configuration allows the DTC to access 16M 
bytes of memory. This pin floats to the high impedance 
state when the DTC is not bus master and the M M 1 bit is 
cleared. 


5To-5T3. -Status (bidirectional, 3-state) pins 31-34. 
When the DTC is bus master, these lines are outputs in- 
dicating the type of memo'ry or 110 transaction being per- 
formed. When the DTC is not bus master, the status lines 
are inputs used to detect Interrupt and Segment Trap 
Acknowledge cycles (Table 1). 


Table 1. Status Codes 


ST3 
ST1 
STo 
Transaction/Operation 


Status Code 


GeneratedlDecoded 


o 
0 


o 
0 
a 
o 


0 
0 
1 
1 
0 


0 
Internal Operation 
Memory Refresh 


0 
1/0 Transaction 
1 
Special 1/0 Transaction 


0 
Segment Trap Acknowledge 


o 
o 
o 
o 
o 
o 


0 
1 
Nonmaskable Interrupt Acknowledge 


Generated 
Generated 
Decoc;led 
Decoded 
Decoded 
Decoded 
Generated 
Generated 


0 
Nonvectored Interrupt Acknowledge 


1 
o 
o 
o 
o 


1 
1 
Vectored Interrupt Acknowledge 


0 
0 
Memory Transaclion for DatalDTC Chaining 


0 
1 
Memory Transaction for Stack 


0 
Reserved 
Reserved 
a 
a 
Memory Transaction for Program Fetch (Subsequent Word) 
Generated 


0 
1 
Memory Transaction for Program Fetch (First Word) 


0 
Reserved 
Reserved 


FUNCTIONAL DESCRIPTION 


Channel Initialization 


The Z8016 DTC operates with a minimum of interaction 
with the host CPU. Each channel's operation is deter- 
mined by the settings of its own set of control registers. 
Each channel is initialized when the DTC loads its con- 
trol parameters from memory into its control registers' 
during the chaining operation. To initiate the chaining 
operation, the CPU is required to program the Master 
Mode register and each channel's Chain Address 
register. Then each channel's control registers are 
automatically 
loaded 
by 
the 
DTC 
with 
control 
parameters stored in a chain control table in memory, 
located at the address pointed to by that channel's Chain 
Address register. Once the channel registers are loaded, 
the DTC is ready to perform DMA operations. 
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Initiating DMA Operations. DMA operations can be 
initiated in three ways: 


• Software Request. The CPU can issue Software Re- 


quest commands to start DMA operations on a 
specific channel. This channel must then reque'st con- 
trol of the bus arid perform transfers. 


.. Hardware Request. DMA operations can be started by 
forcing a channel's ·DREQ input Low, as described in 
the Transfer Modes section. 


.. Starting After Chaining. If the Software Request bit of 
the Channel Mode register is loaded with a 1 during 
chaining, the channel will perform the programmed 
DMA operation at the end of chaining. If the channel is 


programmed for Single Operation or Demand mode, it 
will perform the operation immediately. The channel 
will give up the bus after chaining and before the 
operation if the CPU Interleave bit in the Master Mode 
register is set. Note that once a channel starts a 
chaining operation by fetching a reload word, it re- 
tains bus control at least until all of the registers 
specified in the reload word have been loaded from 
memory. 


Transfers 


The Z8016 DTC uses three basic types of operation: 
Transfer, Search, and Transfer-and-Search. 


During a Transfer operation, the DTC obtains control of 
the system AID bus from the CPU. Data is read from one 
addressable port (source) and is written to another ad- 
dressable port (destination) in words or bytes. This ap- 
plies to both Flyby and Flowthrough transfers. 
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MEMORY 
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~ 


Flyby transfers use a single addressing/transfer cycle, in 
which data is transferred directly from the source to the 
destination with no intermediate storage (Figure 3). This 
method of transfer provides higher throughput than 
Flowthrough transfers but cannot be used for memory- 
to-memory transfer. 


Flowthrough transfers are used for all combinations of 
addressable memory and I/O spaces. These transfers 
use independent double Addressing/Transfer cycles, in 
which data is stored temporarily in 'the DTC while being 
transferred from Source to destination (Figure 4). 
Flowthrough transfers can use the funneling option, 
which allows mixing of data sizes between source and 
destination. For example, a byte-oriented peripheral can 
conveniently supply data to a word-oriented memory. 
This option requires no added circuitry for either 
memory o'r peripherals. 
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Figure 3. Configuration of a Flyby Transaction 
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Figure 4. Configuration of a Flowthrough Transaction 
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During a Search operation,data is read from the source 
port and compared byte-by-byte with a pattern register 
containing a programmable match byte. The Search 
operation can be programmed to stop .either when the 
read data matches (Stop-on-Match) or when it fails to 
match the masked pattern (Stop-on-No-Match). For 
word reads, the Channel Mode register can be used to 
select either 8- or 16-bit compares. 


Transfer-and-Search operations combine the transfer 
and search functions to facilitate the transfer of variable- 
length data blocks. While data is being transferred be- 
tween two ports, a simultaneous search is made for a 
bit-maskable byte match. Transfer-and-Search can, be 
performed in either Flowthrough or Flyby mode. A Flyby 
Transfer-and-Search 
can 
be, used 
to 
increase 
throughput for transfers between peripherals or between 
memory and a peripheral; it cannot be used for memory- 
to-memory transfers. 


Transfer Modes. The Z8016 DTC operates in either of 
two transfer modes: Single or Demand. The Demand 
mode is further divided into the Demand Dedicated with 
Bus Hold, Demand Dedicated with Bus Release, and De- 
mand Interleave modes. 


The Single mode is used with peripherals that transfer 
single bytes or words at irregular intervals. Each Soft- 
ware Request command causes the ch?nnel to perform 
a single DMA operation and each application of a High- 
to-Low transition on the DREQ input also initiates a DMA 
operation. Each time a Single mode DMA operation 
ends, the channel relinquishes the bus unless a new 
transition has occurred on DREQ. 


In the Demand mode, when the DREQ input is active, 
transfer cycles are executed repeatedly until the 
transfer is completed. In the Demand Dedicated with 
Bus Hold mode, the active channel retains control of the 
bus until the transfer is complete, even after the DREQ 
input has gone inactive. In the Demand Dedicated with 
Bus Release' mode, the active channel releases control 
of the bus when the DREQ input goes inactive. When the 
DREQ input becomes active again, control of the bus is 
re-acquired and the transfer operation continues. 


The Demand Interleave mode has two options, program- 
mable in the Master Mode register bit MM2. If MM2 is 
set, the DTC relinquishes and re-requests bus control 
after every DMA operation. 


This permits the CPU and other devices to gain bus con- 
trol. If both channels receive a'ctive DREQ inputs, each 
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channel relinquishes control to the CPU after each 
operation. In the second option (MM2 is 0), control can 
pass from one channel to the other without requiring the 
DTC to release bus control. If both channels receive ac- 
tive DREQ inputs, control alternates between channels 
and the DTC retains bus control until all channel opera- 
tions are complete. 


Wait States. The Z8016 DTC can insert Wait cycles in- 
to the DMA Transaction cycle under hardware or soft- 
ware control. The CS/WAIT input can be multiplexed to 
function as a Chip Select for the DTC when it does not 
have control of the bus, and as a WAIT input when the 
DTC is the bus controller. Multiplexing CS and WAIT re- 
quires external logic, but the DTC can be programmed to 
insert Wait states automatically without external logic 
when accessing either I/O or memory addresses. Either 
zero, one, two, or four Wait states can 'be added. Wait 
states can be programmed separately for the Current 
Address registers and for the Chain Address register. 
Programmable Wait cycle insertion allows memories 
and peripherals of different speeds to be associated with 
I/O and memory addresses. 


Interrupts. Or) the Z8016 DTC, each channel is an inter- 
rupt source and has its own vector register for identify- 
ing the source of the interrupt during a CPUIDTC Inter- 
rupt Acknowledge transaction. An interrupt can result 
from a Match Condition (MC), End-Of-Process (EOP), or 
Terminal Count (TC) on either channel. The user selects 
the action to be performed by setting bits in the Channel 
Mode register. 


Three bits in each channel's Status register control inter- 
rupts. These are the Channel Interrupt Enable (CIE) bit, 
the Interrupt Pending (IP) bit, and the Interrupt Under 
Service (IUS) bit. 


Devices connected to any of the CPU's three interrupt 
inputs resolve priority conflicts with an interrupt daisy 
chain, as shown in Figure 5. The daisy chain has two 
functions. During an Interrupt Acknowledge transaction, 
it 
determines 
which 
interrupt 
source 
is 
being 
acknowledged. At all other times, it determines which in- 
terrupt sources can initiate an interrupt request. 


The Z8016 DTC has an interrupt queuing capability, 
which includes a two-deep interrupt queue on each 
channel. This allows the DTC to continue normal opera- 
tion between the time an interrupt is issued and the time 
the In'terrupt Acknowledge is received. 
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Figure 5. Interrupt Daisy Chain 


Termination 


DMA operations can end in one of the following three 
ways: 


o A Terminal Count (TC) termination occurs when a 
channel's Current Operation Count register goes to O. 


MEMORY MANAGEMENT 


The DTC can be configured to operate in physical ad- 
dress space or logical address space. When the DTC is 
operated in logica1 address space, the segment and off- 
set portions of the address registers combine to form 
23-bit logical addresses. In conjunction with a CPU, DMA 
operations can be handled through the Z8010 MMU or 
the Z8015 PMMU. MMUs offer dynamic segment reloca- 
tion, segment protection,' and other memory manage- 
ment features. 
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D An End-of-Process (EOP) termination occurs when 
the DTC'S EOP pin is driven Low by external logic. 


[J A Match Condition (MC) termination occurs when data 
being Searched or Transferred-and-Searched meets 
the match condition programmed in the Channel 
Mode register. 


In the physical address space configuration, the seg- 
ment and offset portions of the DTC's address registers 
are combined with the SN7 output to form a single 24-bit 
linear address. The extended I/O addressing capability 
of the DTC can be used to increase the DTC's physical 
I/O address space beyond that of the CPU. Figure 6 il- 
lustrates various DTC configuration options with the 
Z8000 CPUs and MMUs. 
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INTERNAL STRUCTURE 


The internal structure of the ZS016 OTC includes driver 
and receiver circuitry for interfacing with Zilog's Z-BUS. 
The OTC's internal bus interfaces with the Z-BUS and 


EXTERNAL BUS 
t 


CHANNEL 1 
REGISTERS 
INTERNAL BUS 


MASTER MODE 


COMMAND 


CHAIN 
CONTROL 


TEMPORARY 


services all internal logic and registers, as illustrated in 
the OTC block diagram (Figure 7). 
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Figure 7. Dle Block Diagram 


REGISTER DESCRIPTION 


The OTC contains chip-level control registers as well as 
channel-level registers that are duplicated for each 
channel. Registers on the OTC that can be read by the 
CPU are either fast- or slow-readable. CPU I/O instruc- 
tions can read fast- readable registers without Wait 
states. Slow-readable registers can be read by the CPU 
only if Wait states are inserted. This requires external 
logic to generate and time the application of Low signals 
on the CPUs WAIT input if the slow-readable registers 
are to be read. 


Control Registers 


The four control registers direct the functioning of the 
OTC. (Figure S.) 


Master Mode Register. This register selects the way in 
which the OTC interfaces to the system. The following 
descriptions indicate how the individual bits in the 
Master Mode register are used. The Master Mode 
register is fast- readable. 


Chip Enable (CE). The setting of this bit enables the OTC 
to request the bus, perform OMA operations and reload 
registers. 
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Logical/Physical Address Space (LPA). The setting of 
this bit determines how the system will view the segment 
and offset portions of the Current ARA and ARB 
registers. When LPA is set to 1 (Logical Address Space), 
the segment and offset portions of the Current ARA and 
ARB registers are treated as separate portions of the ad- 
dress. The 16-bit offset portion' of the address will ap- 
pear on pins AOO-A015 when AS is Low. The 7-bit seg- 
ment number appears on pins SNo-SN6 for the duration 
of the transaction. 


When this bit is set to 0 (Physical Address Space), the 
segment and offset portions of the Current ARA and ARB 
registers are treated as a single address and all eight 
segment bits in the register are used. Both the I/O and 
the memory addresses in PhYSical Memory Space are 
generated by loading the offset portion of the Current Ad- 
dress register onto the AOO...;,A015 bus and the segment 
portion of that register onto the SNo-SN7 bus. (In con- 
junction with the nonsegmented ZSOOO CPUs, either 
Logical or Physical Address Space setting may be used.) 


Wait Line Enable (WLE). This bit is set to enable sam- 
piing' of the CS/WAIT line during memory and I/O 
transactions. 
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Disable Lower Chain (DLC). This bit is set to inhibit all 
lower priority devices on the interrupt daisy chain. While 
DLe is 0, the DTe generates Low and High signals on the 
lEO output in response to lEI. 


No Vector on Interrupt (NVI). This bit determines 
whether the DTe channel or a peripheral returns a vec- 
tor during Interrupt Acknowledge cycles. While the bit is 
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cleared, a channel receiving an Interrupt Ackn9wledge 
will drive the contents of its Interrupt Save register onto 
the AID bus while DS is Low. While this bit is set, inter- 
rupts are serviced in an identical manner, but the AID 
bus remains in a high impedance state throughout the 
Acknowledge cycle. 
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Figure 8. Control Registers 
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CHAIN ADDRESS (2 WORDS) 


CHANNEL MODE (2 WORDS) 


INTERRUPT VECTOR (1 WORD) 


PATTERN AND MASK (2 WORDS) 


BASE OP·COUNT (1 WORD) 


BASE ARB (2 WORDS) 


BASE ARA (2 WORDS) 


CURRENT OP·COUNT (1 WORD) 


CURRENT ARB (2 WORDS) 


CURRENT ARA (2 WORDS) 
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Interrupt Acknowledge Field (two bits). This field is used 
to select the type of Interrupt Acknowledge cycle the 
OTC is to respond to. The setting of this field must cor- 
respond to the 'IEIIIEO daisy chain on which the OTC is 
located. The OTC can respond to Nonmaskable Interrupt 
(NMI), Nonvectored Interrupt (NVI), or Segment Trap 
Acknowledge cycles. 


CPU Interleave Enable. When this bit is set, interleaving 
of bus use between the CPU and the OTC is enabled. 


Chain C,ontrol Register. This 16-bit register specifies 
which registers are to be loaded from memory during a 
chaining operation. The Chain Control register is loaded 
from the memory location pointed to by the Chain Ad- 
dress register. The Chain Control register is chain 
loadable only and cannot be accessed by the CPU. 


Comm'.lnd Register. The Command register is an 8-bit 
write-only register written to by the host CPU to execute 
commands. The Command register is loaded from the 
data on A07-AOO; the data on A015-A08 is disregarded. 


Temporary Register. This 16-bit register is used to 
hold data during Flowthrough transfers, Search opera- 
tions, and Transfer-and-Search operations. The Tem- 
porary register cannot be written or read by the CPU. 


Channel· Level Registers 


Each of the OTC's two channels has a complete set of 
channel-level registers. This set consists of both 
General-Purpose and Special-Purpose registers, as il- 
lustrated in Figure 9. The General-Purpose registers are 
commonly found on OMA devices and can be read or 
written by the CPU. The Special-Purpose registers pro- 
vide additional features specific to the Z8016 OTC. 


General·Purpose 
Registers. The 
General-Purpose 


register set on each channel consists of the Current Ad- 
dress registers A and B, the Base Address registers A 
and B, the Base and Current Operation Count registers, 
and the Channel Mode register (Figure 10). ' 


Current and Base Address Registers A and B. The 
Current Address registers A and B are used to point to 
the source and destination for OMA operations. The con- 
tents of the Base Address registers A and B are transfer- 
red into the Current Address registers A and B at the end 
of a OMA operation if the user enables base-to-current 
reloading in the Completion field of the Channel Mode 
register. The base-to-current reload operation facilitates 
repetitive OMA operations without the multiple memory 
,accesses required by chaining. 


Each of the Base and Current Address registers A and B 
consist of two words. The first word contains a 7 -bit Tag 
field and an 8-bit Segment Number field. The second 
word contains a 16-bit offset. The use of the Tag field is 


described below. The use of the Segment Number field 
depends upon the setting of the LPA bit in the Master 
Mode register. The Base and Current Address registers 
are fast-readable and can be loaded by chaining. 


Programmable Wait Field. This field allows the insertion 
of zero, one, two, or four Wait states into memory or 110 
accesses addressed by the offset and segment fields. 


Address Control Field. At the end of each iteration of a 
OMA operation, the address can be incremented, 
decremented, or left unchanged. Memory addresses are 
changed by one if the address points to a byte operand 
or by two if the address pOints to a word operand. 


Address Reference Field. This portion of the Tag field is 
used to select whether the address pertains to memory 
space or 110 space. The N/S output line is always Low 
(indicating System) for 110 space but can be either High 
(Normal) or Low (System) for memory space. 


Current and Base Operation Count Registers. The 
16-bit Current Operation Count register specifies the 
number of words or bytes to be transferred, searched, or 
transferred-and-searched. For word-to-word operations 
and byte-word funneling, this register must be program- 
med with the number of words to be transferred or 
searched. 


The Base Operation Count register reinitializes the cur- 
rent source and destination in the Current Operation 
Count register. Each time data is transferred or search- 
ed, the Current Operation Count register is decremented 
by one. Once all of the data is transferred or searched, 
the Current Operation Count register will contain zero. If 
the transfer on search stops before the Current Opera- 
tion Count register reaches zero, the contents of the 
register indicate the number of bytes or words remaining 
to be transferred or searched. This allows a channel to 
be restarted from where it left off without requiring 
reloading of the Current Operation Count register. The 
Cu rrent and Base Operation Count registers are slow- 
readable and can be loaded by chaining. 


Channel Mode Register. This register selects the type 
of OMA operation the channel is to perform, how the 
operation is to be executed, and what action is to be 
taken when the operation finishes. The Channel Mode 
register is slow- readable and can be loaded by chaining. 


Data Operation and Transfer Type Field. These fields 
are used to select the type of operation the channel is to 
perform along with the operand size. The specific codes 
are listed in Tables 2 and 3. The Flip bit is used to select 
which of the Current Address Registers A (ARA), or B 
(ARB), points to the source and which pOints to the 
destination address. 
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Figure 9. Channel·Level Registers 
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Figure 10. General·Purpose Channel Registers 
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Table 2. Data Operation Field 


Operand Size 
Transaction 
CodelOperation 
ARA 
ARB 
Type 


Transfer 


0001 
Byte 
Byte 
Flowth rough 


100X 
Byte 
Word 
Flowthrough 
0000 
Word 
Word 
Flowthrough 
0011 
Byte 
Byte 
Flyby 
0010 
Word 
Word 
Flyby 


Transfer·and·Search 


0101 
Byte 
Byte 
Flowthrough 
110X 
Byte 
Word 
Flowthrough 
0100 
Word 
Word 
Flowthrough 
0111 
Byte 
Byte 
Flyby 
0110 
Word 
Word 
Flyby 


Search 


1111 
Byte 
Byte 
N/A 


1110 
Word 
Wo'rd 
N/A 


101X 
Illegal 


Completion Field. This field is used to program the ac- 
tion taken by the channel at the end of a DMA operation. 
When a DMA operation ends, the channel can perform 
any combination of the following options: 


[J Interrupt the CPU (Interrupt Enable field) 


[J Base-to-Cu rrent reload (B to C Reload field) 


[J Chain reload the next DMA operation (Chain Enable 
_ field) 


The options are performed according to the bits set in 
the Interrupt Enable, B to C Reload, and Chain Enable 
fields for each type of termination that occurs; the NAC 
bit in the Status register is automatically set on comple- 
tion of a DMA operation. 


Match Control Field. This 2-bit field determines whether 
matches use an 8-bit or 16-bit pattern and whether the 
channel is to Stop-On-Match or Stop-On-No-Match. The 
specific codes for the Match Control field are listed in 
Table 3. 


Table 3. Transfer Type Field and Match Control Field 


Code 
Transfer Type 
Match Control 


00 
Single Tra[lsfer 
Stop on No Match 


01 
Demand Dedicated/Bus Hold, Stop on No Match 


10 
Demand Dedicated/Bus 
Release 
Stop on Word 
Match 
11 
Demand Interleave 
Stop on Byte Match 
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Pulse DACK (PD). This bit determines when the DACK 
line is active. While cleared, the channel's DACK line is 
active whenever the channel is performing a DMA 
operation, regardless of the type of transaction. While 
the PD bit -is set, the DACK pin is inactive during chain- 
ing, Flowthrough Transfers, Flowthrough Transfer-and- 
Searches, and Searches. DACK is pulsed active during 
Flyby Transfers and Flyby Transfer-and-Searches at the 
time necessary to strobe data into, or out of, the Flyby 
peripheral. 


Hardware Request Mask (HRM). If this bit is set, a DMA 
operation can be started by applying a low on the chan- 
nel's DREQ input. 


Software Request (SR). If this bit is set during chaining, 
the channel performs the programmed DMA operation at 
the end of the chaining operation. 


Special 
Purpose 
Registers. The 
Special-Purpose 
registers on each channel are the Pattern and Mask 
registers, the Status register, the Interrupt Vector 
register, the Interrupt Save registers, and the Chain Ad- 
dre'ss register (Figure 11). 


Pattern and Mask Registers. These registers are used 
in Search and Transfer-and-Search operations. The Pat- 
tern register contains the pattern that the read data is 
compared to. The Mask register allows the user to ex- 
clude or' mask selected Temporary register bits from 
comparison by setting the corresponding Mask register 
bit to 1. The Pattern and Mask registers are slow- 
readable and can be loaded by chaining. 


Status Register. The Status register on each channel 
reports the status of that channel. The functions of the 
individual bits are indicated in the following field descrip- 
tions. The Status register is fast-readable. 


Completion Status Field. Three bits indicate whether the 
DMA operation ended as a result of TC, MC, or EOP. The 
TC bit is set if the Operation Count (reaching zero) ends 
the DMA operation. The MC bit is set if a pattern match 
termination occurs. The EOP bit is set when an EOP ter- 
mination ends a DMA transfer. The appropriate combina- 
tion of the TC, MC, and EOP bits is set if multiple reasons 
exist for ending a DMA operation. The Match Condition 
High byte (MCH) and Match Condition low byte (MCl) 
bits report the match states of the upper and lower com- 
parator bytes of the last word transferred. The MCH and 
MCl bits are updated with each transfer. 


These bits are set when the associated comparator 
bytes are. matched, regardless of whether Stop-on- 
Match or Stop-on-no-Match is programmed. 


Hardware Interface Status Field. The Hardware Re- 
quest (HRQ) bit provides a means of monitoring the 
channel's DREQ input line. While DREQ is low, the HRQ 
bit is set. While the Hardware Mask (HM) bit is set, the 
DTC is prevented from responding to a low on the DREQ 
line. However, the HRQ bit always reports the status of 
DREQ regardless of the status of the HM bit. 


OTC Status Field. This field reports the current channel 
status to the CPU. The "channel initialized and waiting 
for request" status is implicitly indicated if bits ST12 
through ST9 are clear. 


Second Interrupt Pending (SIP). When a second inter- 
rupt is to be issued before the first interrupt is 
acknowledged, this bit is set and the channel relin- 
quishes the bus until an Acknowledge occurs. 


Waiting for Bus (WFB). This bit is set when the channel 
is waiting for bus control to perform a OMA operation. 


No Auto-Reload or Chaining (NAC). This bit is set under 
the following conditions: 


II A channel completes a OMA operation and neither 
Base-to-Current reloading nor auto-chaining is en- 
abled. 


• A channel is issued an EOP during chaining. 


II A Reset is issued to the OTC. 


Chaining Abort (CA). This bit is set when a channel is 
issued an EOP during chaining or a Reset is issued to the 
OTC. The Chain Abort (CA) bit holds the No Auto-Reload 
or Chaining (NAC) bit in the set state until the EOP bit is 
cleared. The CA bit is cleared when a new Chain Address 
Segment and Tag word or Offset word is loaded into the 
channel. 


Interrupt Status Field. The Channel Interrupt Enable 
(CIE), Interrupt Pending (IP), and Interrupt Under Service 
(IUS) bits are used to control the way a channel 
generates an interrupt. An interrupt source with its IP bit 
set makes an interrupt request if all of the following con- 
ditions are met: Interrupts are enabled, (CIE bit = 1), 
there is no InterrLipt Under Service (IUS bit = 0), no 
higher priority interrupt is being serviced, and no Inter- 


rupt Acknowledge transaction is in progress. When an 
interrupt source has an Interrupt Under Service (IUS 
= 1), all lower priority interrupt sources are prevented 
from requesting interrupts. 


Interrupt Vector and Interrupt. Save Registers. The 
8-bit Interrupt Vector register contains the vector or 
identifier to be output during an Interrupt Acknowledge 
cycle. When an interrupt occurs, the contents of the In- 
terrupt Vector register and bits ST9-ST15 of the Status 
register are stored in the 16-bit Interrupt Save register. 
Because the vector and status are stored, a new v~ctor 
can be load~d during ch,aining and a new OMA operation 
can be performed before an Interrupt Acknowledge cy- 
cle occurs. If another interrupt occurs on the channel 
before the first is acknowledged, further channel activity 
is suspended. When a clear I P command is issued, the 
status and vector' for the second interrupt are loaded into 
the Interrupt Save register and channel operation 
resumes. The OTC can retain only two interrupts for 
each channel. The Interrupt Save register is fast- 
readable. 


Chain Address Register. This register points to the 
chain control table in memory containing data to be load- 
ed into the channel's registers. The Chain Address 
register consists of two words (Figure 11). The first word 
consists of a Segment and Tag field. The second word 
contains the 16-bit offset portion of the memory address. 
Bit 15 in the Segment field is ignored when the OTC is 
configured for logical address space (LPA = 1). The Tag 
field contains two bits used to designate the number of 
Wait states to be inserted during accesses to the Chain 
Control table. The Chain Address register is fast- 
readable and is loadable by chaining. 


Table 4 provides a list of register addresses. 
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Figure 11. Specia,I.Purpose Channel Registers 
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Table 4. Register Address Summary 


Address 
(AD7-ADo) 
(Hex) 
Control Registers 


X011100X 
38 
Master Mode 


X010111X 
2E 
Command Channel 1 


X010110X 
2C 
Command Channel 2 


General·Purpose Channel Registers 


X001101X 
1A 
Current Address Register A-Channel 1, SegmentlTag 


XOO0101X 
OA 
Current Address Register A-Channel 1, Offset 


X001100X 
18 
Current Address Register A-Channel 2, SegmentlTag 


XOO0100X 
08 
Current Address Register A-Channel 2, Offset 


X001001X 
12 
Current Address Register 8-Channel 1, SegmentlTag 


XOOOO01X 
02 
Current Address Register B-Channel 1, Offset 


X001000X 
10 
Current Address Register B-Channel 2, SegmentlTag 
N 
XOOOOOOX 
00 
Current Address Register B-Channel 2, Offset 
CO 
~ 
X001111X 
1E 
Base Address Register A-Channel 1, SegmentlTag 
..... 
Ol 


X 0001 1 1 X 
OE 
Base Address Register A-Channel 1, Offset 
ft:J 
X001110X 
1C 
Base Address Register A-Channel 2, SegmentlTag 
val 
XOO0110X 
OC 
Base Address Register A-Channel 2, Offset 
DoiJ 
6 
X001011X 
16 
Base Address Register B-Channel 1, SegmentlTag 


X000011 X 
06 
Base Address Register B-Channel 1, Offset 


X001010X 
14 
Base Address Register B-Channel 2, SegmentlTag 


XOOO010X 
04 
Base Address Register B-Channel 2, Offset 


X011001X 
32 
Current Operation Count Channel 1 


X011000X 
30 
Current Operation Count Channel 2 


X011011X 
36 
Base Operation Count Channel 1 


X011010X 
34 
Base Operation Count Channel 2 


Special· Purpose Channel Registers 


X100101X 
4A 
Pattern Channel 1 


X100100X 
48 
Pattern Channel 2 


X100111X 
4E 
Mask Channel 1 


X100110X 
4C 
Mask Channel 2 


X010111X 
2E 
Status Channel 1 
X 01 0 1 1 0 X 
2C 
Status Channel 2 


X010101X 
2A 
Interrupt Save Channel 1 


X010100X 
28 
Interrupt Save Channel 2 


X101101X 
5A 
Interrupt Vector Channel 1 


X101100X 
58 
Interrupt Vector Channel 2 


X010011X 
26 
Chain Address, Channel 1 SegmentlTag 


X010001X 
22 
Chain Address, Channel 4 Offset 


X010010X 
24 
Chain Address, Channel 2 SegmentlTag 
X 0 1,0000 X 
20 
Chain Address, Channel 2 Offset 


X101011X 
56 
Channel Mode Channel 1 High 


X101001X 
52 
Channel Mode Channel 1 Low 


X101010X 
54 
Channel Mode Channel 2 High 


X101000X 
50 
Channel Mode Channel 2 Low 


NOTE: X = ignored. 


251 


ADDRESSING 


The address generated by the DTC is always a byte ad- 
dress, even though the memory is organized as 16-bit 
words. All word-sized data is word-aligned and must be 
addressed by even addresses (Ao = 0). With byte 
transfers, the least significant address bit determines 
which half of the AID bus is used for the transfer. An· 


COMMANDS 


The Z8016 DTC responds to several commands that give 
the CPU direct control over operating parameters. The 
commands described below are executed immediately 
after being written by the CPU into the DTC's Command 
register. A summary of the DTC commands is given in 
Table 5. 


Reset· 


The Reset command forces the DTC into an idle state, in 
which it waits for a Start Chain command. The Start 
Chain command initiates a chain operation on either 
channel. 


even address specifies the most significant byte 
(AD8-AD15), and an odd address specifies the least 
significant byte (ADo-AD?). This addressing mechanism 
applies to memory accesses as well as to I/O and 
Special I/O accesses. 


Software Request 


A channel's Software Request command initiates a 
previously programmed transfer. If both channels are 
active, Channel 1 has priority. 


Set/Clear Hardware Mask 


The Set/Clear Hardware Mask command sets or clears 
the Hardware Mask bit in the selected channel's Mode 
register. 


Table 5. DTC Command Summary 
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Command 


Reset 
Start Chain Channel 1 
Start Chain Channel 2 


Clear Software Request Channel 1 
Clear Software Request Channel 2 
Set Software Request Channel 1 
Set Software Request Channel 2 


Clear Hardware Mask Channel 1 
Clear Hardware Mask Channel 2 
Set Hardware Mask Channel 1 
Set Hardware Mask Channel 2 


Clear CIE, IUS, IP Channel 1 
Clear CIE, IUS, IP Channel 2 
Set CIE, IUS, IP Channel 1 
Set CIE, IUS, IP Channel 2 


Clear Flip Bit Channel 1 
Clear Flip Bit Channel 2· 
. Set Flip Bit Channel 1 
Set Flip Bit Channel 2 


Opcode Bits 
7654 
3210 


OOOX 
XXXX 


101X 
XXXO 
101X 
XXX 1 


010X 
XXOO 
010X 
XX01 
010X 
XX10 
010X 
XX11 


100X 
XXOO 
100X 
XX01 
100X 
XX10 
100X 
XX11 


001E 
SPOO 
001E 
SP01 
001E 
SP10 
001E 
SP11 


011X 
XXOO 
011X 
XX01 
011X 
XX10 
011X 
XX11 


Example 


Code 
(HEX) 


00 
AO 
A1 


40 
41 
42 
43 


80 
81 
82 
83 


60 
61 
62 
63 


* NOTES: 1. E = Set to 1 to perform set/clear on CIE, Clear to a for no effect on CIE. 


2. S = Set to 1 to perform set/clear on IUS, Clear to a for no effect on IUS. 
3. P = Set to 1 to perform set/clear on IP, Clear to a for no effect on IP. 
4. X = "don't care" bi"t. This bit is not decoded and may be a or 1. 
5. Flip bit = reset to a for ARA = src, ARB = dst. Set to 1 for ARA = dst, 
ARB = src. 


Set/Clear IP, IUS, and CIE 


The Set/Clear IP, IUS, and CIE commands manipulate 
the Interrupt Control bits located in each channel's 
Status register. These bits implement the interrupt daisy- 
chain control. The IP, IUS, and CIE bits for each channel 
can be set and cleared individually or in combination. 


TIMING 


The following descriptions and timing diagrams refer to 
the relative timing relationships of DTC signals during 
basic operations. For exact timing informatron, refer to 
the composite timing diagrams. 


Bus Request And Acknowledge 


Before the DTC can perform a DMA operation, it must 
gain control of the system bus. The BUSREQ, BAI, and 
BAO interface pins provide connections between the 
DTC and the host CPU and other DMA devices to ar- 
bitrate which device has control of the system bus. 
When. the DTC wants to gain bus control, it drives 
BUSREQ Low. Bus Request and Acknowledge timing is 
shown in Figure 12. 


Flowthrough Transactions 


Timing for Flowthrough 1/0 and Flowthrough Memory 
transactions (Figures 13 and 14, respectively) is iden- 
tical. There are two types of 1/0 space on the Z8016: 1/0 
and Special 1/0. Status lines STo-ST3 specify when an 
1/0 operation is being performed and which of the two 
1/0 spaces is being accessed. During an I/O transaction, 


DREQ~ L 
~ 
J 


~, 
BUSREQ 
.; 


BAI 
'~ 
, 


STo-ST3, AS { 
I:> 
DS,R/W 
CPU 
B/W, N/S 
(SNo-SN6)" 
,f 


ADo-AD15 { 


~;J 
(SNo-SN7) * * 
CPU 
, 


MMUSYNC" 


7" 


"For logical addressing only. 
""For physical addressing only. 


Set/Clear Flip Bit 


The Set/Clear Flip Bit command reverses the source and 
destination, thereby reversing the direction of data 
transfer without reprogramming the channel. 


status signal NIS will be Low to indicate a System Level 
operation. 


The timing for 1/0 operations is identical to the timing of 
Flowthrough memory transactions. An 1/0 cycle consists 
of three states: T1, T2, and T3. The TWA state is a Wait 
state that can be inserted into the transaction cycle. The 
AS output is pulsed Low to mark the beginning of a 
T-cycle. The NIS line is set Low (System) and the R/W 
and BIW lines select Read or Write operations for bytes 
or words. The NIS, R/W and BIW lines become stable 
during T1 and remain stable until the end of T3. 


1/0 address space is byte-addressed but both 8- and 
16-bit data sizes are supported. During 1/0 transactions, 
the BIW output is High for byte transactions and Low for 
word transactions. 


The R/W output is High during Read operations and Low 
during Write operations. OS is driven Low to signal the 
peripherals that data can be gated onto, or received 
from, the bus. OS is driven High to signal the end of the 
1/0 transaction. 


1./ 


/ 


,.I- 


/1 


1/ 
,r--F 
, 


( 
DTC >C 


DTC 
}--,-~ 
c; 


DTC 
>-a 
~, 
, 
,'I 


Figure 12. Bus Request and Acknowledge Timing 
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CLOCK 


I 


STo-ST3, B/W ~ 


(SNO-SN7)* * --A 


N/S 


- 


MMUSYNC* 
\ 
-~ 


LOW 


(SNo-SNu) * 
X 
__ ~ 
______________ ~ 
__________________________________ -J ~ 
________________ _ 


READ 


IN 


AD 


R/W 


PORT ADDRESS 


AD 
X 
PORT ADDRESS X 
DATA OUT 


WRITE 
OUT 
OS 


R/W 
\ 


* For logical addressing only. 
* * For physical addressing only. 


Figure 13. Flowthrough I/O Transaction Timing 
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r 


2129-013 


2129-014 


I~T3~I~T1---'I~T2~I~T3-'1 


CLOCK 


STO-ST3,B/W ------------------~ 
N/S 


(SNo-SN7) * * --..... ------------.... ", 


(SNO-SNO)* 


MMUSYNC* 


AD 


READ 


R/W 


AD 


WRITE 


R/W 


* For logical addressing only. 
* * For physical addressing only. 


MEMORY 
ADDRESS 


MEMORY 
ADDRESS 


INSERT WAIT STATE 


DATA OUT 


Figure 14. Flowthrough Memory Transaction Timing 


I 
... • i 
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· Flyby Transactions 


A Flyby operation is performed during three T-states. AS 
is pulsed during T1 to signal the output of address infor- 
mation. R/W is High if the current ARA specifies source, 
and Low if the current ARB specifies destination. OS and 


CLOCK 


STe-ST3 
BiW, HIS*** 


(sNo-sN7)·· 


MMUSYHC* 


(SHe-SHe)* 


TO FLYBY 
PERIPHERAL 


FROM FLYBY 
PERIPHERAL 


AD 


ADDRESS (B) 


*Toggles for memory access in logical address space only. 
*:: For p~ysical addressing only. 


N/S Will be low for 110 transactions. 


(A) Address is current ARA 
(B) Address is current ARB 


OACK are driven active during T2 to initiate the transfer, 
and driven inactive during T3 to conclude the transfer. 
Wait states can be inserted between T2 and T3 to extend 
the active time to OS and OACK. Flyby transaction tim- 
ing is shown in Figure 15. 


Figure 15. Flyby Transaction Timing 


256 
2129-015 


DREQ Timing 


The following section describes DREQ timing for various 
operations. 


A High-to-Low transition of DREQ causes a single itera- 
tion of a DMA operation. A new transition can occur after 
the Low-to-High AS transition on the first memory or I/O 
access of the DMA iteration. Figure 16 shows the timing 
for a new transition to be applied and recognized to 
avoid giving up the bus at the end of the current iteration. 


In Bus Hold mode, DREQ is sampled when a channel 
gains bus control. If DREQ is Low, an iteration of a DMA 
operation is performed. If DREQ is High, the channel re- 
tains bus control and continues to drive all bus control 
signals active or inactive, but performs no DMA 
operation. 


In Demand mode during DMA operation, DREQ is sam- 
pled to determine whether the channel should perform 
another cycle or release the bus (Figure 17). 


DREQ is sampled after each Ene:! qf Chaining or Base-to- 
Current Reloading operation. If UREQ is active, the 
channel begins performing DMA operations immedi- 
ately, without releasing the bus. 


DACK Timing 


. During I/O and memory transactions, WAIT is sampled in 
the middle of T2. If WAIT is High, and no programmable 
Wait states are selected, the DTC proceeds to T3. Other- 
wise, one or more Wait states are inserted. WAIT is also 
sampled during TWA. If WAIT is High the DTC proceeds 
to T3, otherwise, additional Wait states are inserted. 
When both hardware and software Wait states are in- 
serted, each WAIT time is sampled. A Low causes a 
hardware Wait state to be inserted in the next cycle. 
Software Wait state insertion is suspended until WAIT is 
High. Hardware Wait states can be inserted any time 
during the software Wait state sequence. DACK timing is 
shown in Figure 18. 


EOP Timing 


EOP is driven Low when a TC, MC, or EOP termination 
occurs. When a DMA operation has terminated, EOP is 
sampled on the falling edge of T3 to determine if EOP has 
been driven Low. The generation of internal EOPs and 
sampling of external EOPs for Transfers-and-Searches 
follows the same timing used for Transfers. EOP timing 
is shown in Figure 19. 


1 :'R8T ACCESS OF DMA ITERATION 
LAST. ACC. ESS OF DMA ITERA. TION .. I 
T14<1---T2~.r--TWA or T2--l>~T3 


CLOCI( 
\'----I:r-: _\~-r.-/ __ 


Figure 16. Sample DREQ During Single Transfer DMA Operations 
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1"-THLO-----.j...--THLO-----.I~ THLO-----'r---TS--"~I"''''~-T1__1 


CLOCK 


\~--\~/_-------------- 


(A) Sampling of DREO While in Bus Hold Mode 


I 
LAST ACCESS OF DMA ITERATION 
I FIRST ACCESS OF NEXT DMA ITERATION 


r---T2 or T1-----1~TwA or T2~r----T3---''--T1---''~T2~1 


CLOCK 


\ 
/ 


(B) DREO Sampling in Demand Mode During DMA Operations 


j..--T2 or T1~I""-TWA or T2 --.1"--T3---'1~ T1P--.I~Ts---..l..--T1-- 


CLOCK 


\ / 


(C) Sampling DREO at the End of Chaining 


I~TAU2-------..I~TAU3----"I~TAU4-------"I~TCO----ilo--I~Ts~I~T1-- 


CLOCK 


\ / 


(D) Sampling DREO at End of Base-to-Current Reloading 


Figure 17_ DREQ Sampling in Demand Mode 
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CLOClt 
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I~T1--"I~T2~I""'--T3---..I~T1P~I~TS- 


\~ _____ 
.....JI 


PULSED 


DACK (FLYBY) 
\ 


TO I 
f 
FROM 
"" ___ 
F_L_YB_Y_ ........ _____ .-FLYBY 


2129-018,019 


CLOCK 


EXTERNAL 


EOP 


110-1/0 
I/O-MEM 
Y/""""'--- 


Figure 18. DACK Timing 


I~THLD~I-.--THLD-..I.-TIDLE-- 


I~TWA orT2--.I~T3---I~~I~T1P---.I~TAU1- 


CLOCK 


~T~NM 
\ 
/ 
EOP ________________ 
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__________________________________ ___ 


INTERNAL 
EOP 


Figure 19. EOP Timing 
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ACTIVE STATE TIMING 
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AC CHARACTERISTICS 


Min (ns) 
Max (ns) 
No. Symbol 
Description 
(4 MHz) 
(4 MHz) 


1 TcC 
Clock Cycle Time 
250 
2000 


2 TwCh 
Clock Width (High) 
105 


3 TwCI 
Clock Width (low) 
105 


4 TfC 
Clock Fall Time 
20 


5 TrC 
Clock Rise Time 
20-- 


6 TdC(SNv) 
ClK I to Segment Number Valid (50pF load) Delay 
110 


7 TdC(SNn) 
ClK I to Segment Number Not Valid Delay 
20 


8 TdC(Bz) 
ClK I to Bus Float Delay 
65 
9 TdC(A) 
ClK I to Address Valid Delay 
90 
10 TdC(Az) 
ClK I to Address Float Delay 
65-- 


11 
TdA(DI) 
Address Valid to Data in Required Valid Delay 
400 


12 TsDI(C) 
Data In to ClK I Setup Time 
20 


13 TdDS(A) 
OS I to Address Active Delay 
80 
00 


14 TdC(DO) 
ClK I to Data Out Valid Delay 
90 
CO 


15 ThDI(DS)-'--Data In to OS I Hold Time 
0 
C ... 
16 TdDO(DS) 
Data Out Valid to OS I Delay 
230 
Ol 


17 TdDO(SW) 
Data out Valid to OS I (Write) Delay 
55 
~ 


19 TdC(ASf) 
ClK I to AS I Delay 
70 
'" 
~ 
20 
TdA(AS) 
Address Valid to AS I Delay 
50 
n 


21 
TdC(ASr)---ClK I to AS I,Delay 
70-- 


22 TdAS(DI) 
AS I to Data In Required Valid Delay 
300 


23 TdDS(AS) 
OS I to AS I Delay 
75 
24 TwAS 
AS Width (low) 
80 


25 
TdAS(A) 
AS I to Address Not Valid Delay 
60 


26 TdAz(DSR) -- Address Float to OS (Read) I Delay 
0 


27 TdAS(DSR) 
AS t to OS I (Read) Delay 
75 
28 TdDSR(DI) 
OS (Read) I to Data In Required Valid Delay 
165 
29 TdC(DSr) 
ClK I to OS I Delay 
60 
30 
TdDS(DO) 
OS I to Data Out (Write only) and Status Not Valid 
(Read and Write) Delay 
85 
31 
TdA(DSR) 
Address Valid to OS (Read) I Delay 
120 


32 
TdC(DSR) 
ClK I to OS (Read) I Delay 
60 


33 
TwDSR 
OS (Read) width (low) 
275 
34 
TdC(DSW) 
ClK I to OS (Write) I Delay 
60 


35 TwDSW 
OS (Write) Width (low) 
160 


36 
TdDSI(DI) 
OS (Input) I to Data in Required Valid Delay 
325 
37 
TdC(DSf) 
ClK I to OS (I/O) I Delay 
60 


38 TwOS 
OS (I/O) Width (low) 
160* 


39 TdAS(DS) 
AS t to OS I (ACK) Delay 
100 
40 
TdC(DS) --- ClK I to OS I (ACK) Delay 
100-- 


41 
TdSA(DI) 
OS I (ACK) to Data in Delay 
150 


42 
TdC(S) 
ClK I to Status Valid Delay 
110 


43 
TdS(AS) 
Status Valid to AS I Delay 
60 


44 
TsWT(C) 
WAIT to ClK I Setup Time 
20 


45 
ThWT(C) 
WAIT to ClK I Hold Time 
10 


*Insert Wait states via software or hardware when accessing slow peripherals, 
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INACTIVE STATE TIMING 


ADDRESS 


ADo-AD15 
lOR ------1-1------0( 


lOW -----+-~-O(I 


1/0 


INTERRUPT 
ACKNOWLEDGE 


STO-ST3,R/W, B/W 


BUS EXCHANGE TIMING 


, 


~-----------~~----~~~------~ ~--7?-----~~~----~~ 


"For logical addressing only. 
··For physical addressing only. 


Note 1: The OTC will begin driving t.he bus on the clock cycle following the clock cycle In which the set·up parameters are met. 
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II 


2129·021,022 


AC CHARACTERISTICS (Continued) 


Min (ns) 
Max (ns) 
No. Symbol 
Description 
(4 MHz) 
(4 MHz) 


48 TdDSA(RDZ) 
DS I Acknowledge) to Read Data Float Delay 
60 


. 49 TdDSR(DOD) 
DS I (IOR)to Data Output Driven Delay 
135 


50 
TdDSR(RDZ) 
DS I (lOR) to Read Data Float Delay 
60 


51 
TwAS 1 
AS low Width 
70 


52 
TsA(AS) 
Address Valid to AS I Setup Time 
30 


53 
ThAS(A) 
AS I to Address Not Valid Hold Time 
40 


54 
TsCS(AS) 
CS Valid to AS I Setup Time 
0 


55 
ThCS(AS) 
AS I to CS Not Valid Hold Time 
40 


56 
TdDS(Dn) 
DS I (lOW) to Data Not Valid Delay 
25 
57 TdA(DRV)--' -Address Valid to Data (lOR) Required Valid Delay 
540-- 
58 
TdA(DS) 
Address Float to DS I (lOR) Delay 
0 


59 
TwDS(IO) 
DS (10) low Width 
150 
60 
TsD(DS) 
Data Valid to DS I Setup Time (lOW) 
40 
N 


61 
TrDsh(DSR) 
DS I (lOW) to DS I (lOW) (Write Recover Time applies only for 
00 


issuing command) 
4tcC 
0 ... 


62 
TdASh(DSe) 
AS I to DS I (ACK) Delay 
100 
• 
63 
TwDS(AK1) 
DS (ACK) Width low 
150 
ItI 


64 
TsS(AS) 
Status Valid to AS I Setup Time 
20 
" 
65 
TdDSW(Dn) 
DS I (lOR) to Data Not Valid Delay 
25 
fI 


66 TdASh(DSI)--AS I to DS I Delay (10) 
100 


67 
TsDRO(c) 
DREO Valid to ClK I Setup Time 
50 


68 
ThDRO(C) 
ClK I to DREO Valid Hold Time 
20 


69 
TdC(BROf) 
ClK I to BUSREO I Delay 
150 
70 
TdC(BROr) 
ClK I to BUSREO I Delay 
150 


71 
TdBRO(BAI)-- BUSREO I to BAI I Required Delay 
0 


72 
TsBAK(C) 
BAI Valid to ClK I Setup Time 
50 


73 
TdC(SNv) 
ClK I to Segment No. Valid (50pF load) Delay 
110 


74 
TdC(ASf) 
ClK I to AS I Delay 
70 


75 
TdC(S) 
ClK I to Status Valid Delay 
110 


76 
TdBRO(BUSc)-BUSREO I to Control Bus Float Delay 
140-- 
77 TdC(A) 
ClK I to Address Valid Delay 
90 


78 
TdBRO(BUSd) 
BUSREO I to AID Bus Float Delay 
140 


79 
TdQ(SNr) 
ClK I to SN7/MMUSYNC I Delay** 
110 
80 
TdC(SNf) 
ClK I to SN7/MMUSYNC I Delay** 
20 
110 


**Logical Addressing Only. 
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ABSOLUTE MAXIMUM RATINGS 


Voltages on all inputs and outputs 
with respect to GND ............... ~0.3 V to + 7.0 V 


Operating Ambient 
Temperature ............... See ordering information 


Storage Temperature ............. -65°C to + 150 °C 


STANDARD TEST CONDITIONS 


The characteristics below apply for the following stan- 
dard test conditions, unless otherwise noted. AII,voltages 
are referenced to GND. Positive current flows into the 
referenced pin. Standard conditions are as follows: 


E1 + 4.75 V :5 Vcc:5 + 5.25 V 
c GND = a V 


D TA as specified in Ordering Information 


All ac parameters assume a load capacitance of 50 pF 
max. 


DC CHARACTERISTICS 


Symbol 
Parameter 
Min 


Stresses greater than those listed under Absolute Maximum Ratings 
may cause permanent damage to the device. This is a stress rating 
only: operation of the device at any condition above those indicated in 
the operational sections of these specifications is not implied. Ex- 
posure to absolute maximum rating conditions for extended periods 
, may affect device reliability. 


Max 


+5V 


2.2K 


FROM OUTPUT 


UNDER TEST 


+5V 


~ 


2'2K 


I 


50PF 


. 


Standard Test Load 
Open-Drain Test Load 


Unit 
Condition 


VCH 
Clock Input High Voltage 
Vcc-O.4 
Vcc+ 0.3 
V 
Driven by External Clock Generator 


VCl 
Clock Input Low Voltage 
-0.3 
0.45 
V 
Driven by External Clock Generator 


VIH 
Input High Voltage 
2.0 
VCC+ 0.3 
V 


Vil 
Input Low Voltage 
-0.3 
0.8 
V 


VOH 
Output High Voltage 
2.4 
V 
10H = -250 p.A 


VOL 
Output Low Voltage 
0.4 
VIOL = +2.0 mA 


III 
Input Leakage 
±10 


IOL 
Output Leakage 
±10 
p.A 
0.4 :5 VIN :5 + Vcc 


Icc 
Vcc Supply Current 
350 


NOTE: Vce = 5 V ± 5% unless otherwise specified. 
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ORDERING INFORMATION 


Product 
Package/ 


Number 
Temp 
Speed. 


Z8016 
CS 
4.0 MHz 


Z8016 
PS 
4.0 MHz 


Description 


OTC (48-pin) 


Same as above 


Product 
Paclmge/ 


Number 
Temp 
Speed 


Z8016A 
CS 
6.0 MHz 


Z8016A 
PS 
6.0 MHz 


NOTES: C = Ceramic, P = Plastic; E = -40°C to + 85°C, M = -55°C to + 125 °C, M B =' -55°C to + 125 °C with 


MIL-STD-883 Class B processing, S = O°C to + 70°C. 


00-2129-01 


Description 


OTC (48-pin) 


Same as above 
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Features 


Genoral 
Description 


2016-039, 041 


[J Two independent, 0 to 1M bit/second, full- 
duplex channels, ea~h with a separate 
crystal oscillator, baud rate generator, and 
Digital Phase-Locked Loop for clock 
recovery. 


[J Multi-protocol operation under program 
control; programmable for NRZ, NRZI, or 
FM data encoding. 


[J Asynchronous mode with five to eight bits 
and one, one and one-half, or two stop bits 
per character; programmable clock factor; 
break detection and generation; parity, 
overrun, and framing error detection. 


The Z8030 Z-SCC Serial Communications 
Controller is a dual-channel, multi-protocol 
data communications peripheral designed for 
use with the Zilog Z-Bus. The Z-SCC functions 
as a serial-to-parallel, parallel-to-serial con- 
verter/controller. The Z-SCC can be software- 
configured to satisfy a wide variety of serial 
- 
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IJ Synchronous mode with internal or external 
character synchronization on one or two 
synchronous characters and CRC genera- 
tion and checking with CRC-16 or 
CRC-CCITT preset to either Is or Os. 


[] SDLC/HDLC mode with comprehensive 
frame-level control, automatic zero insertion 
and deletion, I-field residue handling, abort 
generation and detection, CRC generation 
and checking, and SDLC Loop mode 
operation. 


[J Local Loopback and Auto Echo modes. 


communications applications. The device con- 
tains a variety of neW, sophisticated internal 
functions including on-chip baud rate 
generators, Digital Phase-Locked Loops, and 
crystal oscillators that dramatically reduce the 
need for external logic. 
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The Z-SCC handles asynchronous formats, 
synchronous byte-oriented protocols such as 
IBM Bisync, and Synchronous bit-oriented pro- 
tocols such as HDLC and IBM SDLC. This ver- 
satile device supports virtually any serial data 
transfer application (cassette, diskette, tape 
drives, etc.). 
The device can generate and check CRC 
codes in any Synchronous mode and can be 
programmed to check data integrity in various 
modes. The Z-SCC also has facilities for 


The following section describes the pin 
functions of the Z-SCC. Figures 1 and 2 detail 
the respective pin functions and pin 
assignments. 
ADo-AD7' Address/Data Bus (bidirectional, 
active High, 3-state). These multiplexed lines 
carry register addresses to the Z-SCC as well 
as data or control information to and from 
the Z-SCC. 
AS. Address Strobe (input, active Low). 
Addresses on ADo-AD7 are latched by the ris- 
ing edge of this signal. 
CSo. Chip Select 0 (input, active Low). This 
signal is latched concurrently with the 
addresses on ADo-AD7 and must be active for 
the intended bus transaction to occur. 


CSI. Chip Select 1 (input, active High). This 
second select signal must also be active before 
the intended bus transaction can occur. CSI 
must remain active throughout the transaction. 
CTSA. CTSB. Clear to Send (inputs, active 
Low). If these pins are programmed as Auto 
Enables, a Low on the inputs enables their 
respective transmitters. If not programmed as 
Auto Enables, they may be used as general- 
purpose inputs. Both inputs are Schmitt-trigger 
buffered to accommodate slow rise-time inputs. 
The Z-SCC detects pulses on these inputs and 
can interrupt the CPU on both logic level 
transitions. 


DCDA. DCDB. Data Carrier Detect (inputs, 
active Low). These pins function as receiver 
enables if they are programmed for Auto 
Enables; otherwise they may be used as 
general-purpose input 'pins. Both pins are 
Schmitt-trjgger buffered to accommodate slow 
rise-time signals. The Z-SCC detects pulses on 
these pins and can interrupt the CPU on both 
logic level traI'lsitions. 
DS. Data Strobe (input, active Low). This 
signal provides timing for the transfer of data 
into and out of the Z-SCC. If AS and DS coin- 
cide, this is interpreted as a reset. 
DTR/REQA. DTR/REQB. Data Terminal 
Ready/Request (outputs, active Low). These 
outputs follow the state programmed into the 
DTR bit. They can also be used as general- 
purpose outputs or as Request lines for a DMA 
controller. 


modem controls in both channels. In appli- 
cations where these controls are not needed, 
the modem controls can be used for 
general-purpose I/O. 


The i-Bus daisy-chain interrupt hierarchy 
is also supported-as is standard for Zilog 
peripheral components. 
The Z8030 Z-SCC 'is packaged in a 40-pin 
ceramic DIP and uses a single + 5 V power 
supply. 


lEI. Interrupt Enable In (input, active High). 
IEI is used with lEO to form an interrupt daisy 
chain when there is more than one interrupt- 
driven device. A High IEI indicates that no 
other higher priority device has an interrupt 
under service or is requesting an interrupt. 


lEO. Interrupt Enable Out (output, active 
High). IEO is, High only if lEI is High and the 
CPU is not servicing a Z-SCC interrupt or the 
Z-SCC is not requesting an interrupt (Interrupt 
Acknowledge cycle only). IEO is connected to 
the next lower priority device's lEI input and 
thus inhibits interrupts from lower priority 
devices. 
INT. Interrupt Request (output, open-drain, 
active Low). This signal is activated when the 
Z-SCC requests an interrupt. 
INTACK. Interrupt Acknowledge (input, active 
Low). This signal indicates an active Interrupt 
Acknowledge cycle. During this cycle, the 
Z-SCC interrupt daisy chain settles. When DS 
becomes active, the Z-SCC places an interrupt 
vector on the data bus (if lEI is High). 
IN TACK is latched by the rising edge of AS. 


PCLK. Clock (input). This is the master Z-SCC 
clock used to synchronize internal signals. 
PCLK is not required to have any phase rela- 
tionship with the master system clock, although 
the frequency of this clock must be at least 
90% of the CPU clock frequency for a Z8000. 
P.CLK is a TTL level signal. 
RxDA. RxDB. Receive Data (inputs, active 
High). These input signals receive serial data 
at standard TTL levels. 
RTxCA. RTxCB. Receive/Transmit Clocks 
(inputs, active Low). These pins can be pro- 
grammed in several different modes of opera- 
tion. In each channel, RTxC may supply the 
receive clock, the transmit clock, the clock for 
the baud rate generator, or the clock of the 
Digital Phase-Locked Loop. These pins can 
also be programmed for use with the respec- 
tive SYNC pins as a crystal oscillator. The 
receive clock may be 1, 16, 32, or 64 times the 
data rate in Asynchronous modes. 
RTSA. RTSB. Request To Send (outputs, 
active Low). When the Request To Send (RTS) 
bit in Write Register 5 (Figure 11) is set, the 
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RTS signal goes Low. When the RTS bit is 
reset in the Asynchronous mode and Auto 
'Enable is on, the signal goes High after the 
transmitter is empty. In Synchronous mode or 
in Asynchronous mode with Auto Enable off, 
the RTS pin strictly follows the state of the RTS 
bit. Both pins can be used as general-purpose 
outputs. 
R/W. Read/Write (input). This signal specifies 
whether the operation to be performed is a 
read or a write. 


SYNCA, SYNCB. Synchronization (inputs or 
outputs, active Low). These pins can act either 
as inputs, outputs, or part of the crystal 
oscillator circuit. 
In the Asynchronous Receive mode (crystal 
oscillator option not selected), these pins are 
inputs similar to CTS and DCD. In this mode,_ 
transitions on these lines affect the state of the 
Synchronous/Hunt status bits in Read Register 
a (Figure 10) but have no other function. 
In External Synchronization mode with the 
crystal oscillator not selected, these lines also 
act as inputs. In this mode, SYNC must be 
driven Low two receive clock cycles after 
the last bit in the synchronous character is 
received. Character assembly begins on the 
rising edge of the receive clock immediately 
preceding the. activation of SYNC. 


In the internal Synchronizatlon mode 


The functional capabilities of the Z-SCC 


can be described from two different points 
of view: as a data communications device, 
. it transmits and receives data in a wide 
variety of data communications protocols; 
as a Z8000 Family peripheral, it interacts 
with the Z8000 CPU and other peripheral 
circuits and is part of the Z-Bus interrupt 
stru8ture. 
Data Communications Capabilities. Th~ 
Z-SCC provides two independent full-duplex 
channels programmable for use in any com- 
mon Asynchronous or Synchronous data- 
communication protocol. Figure 3 and the 
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(Monosync and Bisync) with the crystal 
oscillator not selected, these pins act as out- 
puts and are active only during the part of the 
receive clock cycle in which synchronous 
characters are recognized. The synchronous 
condition is not latched, so these outputs are 
. active each time a synchronization pattern is 
recognized (regardless of character bound- 
aries). In SDLC mode, these pins act as out- 
puts and are valid on receipt of a flag. 


TxDA, TxDB. Transmit Data (outputs, active 
High) .. These output signals transmit serial data 
at standard TTL levels. 


TRxCA, TRxCB. Transmit/Receive Clocks 
(inputs or outputs, active Low). These pins can 
be programmed in several different modes of 
operation. TRxC may supply the receive clock 
or the transmit clock in the input mode or sup- 
ply the output of the Digital Phase-Locked 
Loop, the crystal oscillator, the baud rate 
generator, or 'the transmit clock in the output 
mode. 
W/REQA, W/REQB. Wait/Request (outputs, 
open-drain when programmed for a Wait func- 
tion, driven High or Low when programmed 
for a Request function). These dual-purpose 
outputs may be programmed as Request lines 
for a DMA controller or as Wait lines to 
synchronize the CPU to the Z-SCC data rate. 
The reset state is Wait.' 


following description briefly detail these 
protocols. 


Asynchronous Modes. Transmission and 
reception can be accomplished independently 
on each channel with five to eight bits per 
character, plus optiorial even or odd parity. 
The transmitters can supply one, one-anQ-a- 
half, or two stop bits per character and can 
provide a break output at any time. The 
receiver break-detection logic interrupts the 
CPU both at the. start and at the end of a 
received break. Reception is protected from 
spikes by a transient spike-rejection 
mechanism that checks the signal one-half a 
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bit time after a Low level is detected on the 
receive data input (RxDA or RxDB in 
Figure 1). If the Low does not persist (as in the 
case of a transient), the character assembly 
process does not start. 
Framing errors and overrun errors are 
detected and buffered together with the partial 
character on which they occur. Vectored inter- 
. rupts allow fast servicing or error conditions 
using dedicated routines. Furthermore, a 
built-in checking process aVQ.ids the interpreta- 
tion of a framing error as a new start bit: a 
framing error results in the addition of one-half 
a bit time to the point at which the search for 
the next start bit begins. 
The Z-SCC does not require symmetric 
transmit and receive clock signals-a feature 
allOWing use of the wide variety of clock 
sources. The transmitter and receiver can 
handle data at a rate of 1, 1/16, 1/32, or 1/64 
of the clock rate supplied to the receive and 
transmit clock inputs. In Asynchronous modes, 
the SYNC pin may be programmed as an input 
used for functions such as monitoring a ring 
indicator. 
Synchronous Modes. The Z-SCC supports both 
byte-oriented and bit-oriented synchronous 
communication. Synchronous byte-oriented 
protocols can be handled in several modes, 
allowing character synchronization with a 6-bit 
or 8-bit synchronous character (Monosync), 
any I2-bit synchronization pattern (Bisync), or 
with an external synchronization signal. 
Leading synchronous characters can be 
removed without interrupting the CPU. 


Five- or 7-bit synchronous characters are 
detected with 8- or I6-bit patterns in the 
Z-SCC by overlapping the larger pattern 
across multiple incoming synchronous 
characters as shown in Figure 4. 
CRC checking for Synchronous byte- 
oriented modes is delayed by one character 
time so that the CPU may disable CRC check- 
ing on specifiC characters. This permits the 
implementation of protocols such as 
IBM Bisync. 
Both CRC-I6 (X16 + XIS + X2 + 1) and 
CCITT (X16 + XI2 + XS + 1) error checking 
polynomials are supported. Either polynomial 
may be selected in all Synchronous modes. 
Users may preset the CRC generator and 
checker to all Is or all Os. The Z-SCC also 
provides a feature th~t automatically transmits 
CRC data when no other data is available for 
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transmission. This allows for high speed 
transmissions under DMA control, with no 
need for CPU intervention at the end of a 
message. When there is no data or CRC to 
send in Synchronous modes, the transmitter 
inserts 6-, 8-, or 16-bit synchronous 
characters, regardless of the programmed 
character length . 
The Z-SCC supports Synchronous bit- 
oriented protocols, such as SDLC and HDLC, 
by performing automatic flag sending, zero in": 
sertion, and CRC generation. A special com- 
mand can be used to abort a frame iri transmis- 
sion. At the end of a message, the Z-SCC 
automatically transmits the CRC and trailing 
flag when the transmitter underruns. The 
. 
transmitter may also be programmed to send 
an idle line consisting of continuous flag 
characters or a steady marking condition. 
If a transmit underrun occurs in the middle 
of a message, an external/status interrupt 
warns the CPU of this status change so that an 
abort may be issued. The Z-SCC may also be 
programmed to send an abort itself in case of 
an underrun, relieVing the CPU of this task. 
One to eight bits per character can be sent, 
allowing reception of a message with no prior 
information about the character structure in 
the information field of a frame. 
The receiver automatically acquires syn- 
chronization on the leading flag of a frame in 
SDLC or HDLC and provides a synchroniza- 
tion signal on the SYNC pin (an interrupt can 
also be programmed). The receiver Can be 
programmed to search for frames addressed by 
a single byte (or four bits within a byte) of a 
user-selected address or to a global broadcast . 
address. In this mode, frames not matching 
either the user-selected or broadcast address 
are ignored. The number of address bytes can 
be extended under software control. For 
receiving data, an interrupt on the first 
received character, or an interrupt on every 
character, or on special condition only (end- 
of-frame) can be selected. The receiver 
automatically deletes all Os inserted by the 
transmitter during character assembly. CRC is 
also calculated and is automatically checked to 
validate frame transmission. At the end of 
transmission, the status of a received frame is 
available in the status registers. In SDLC 
mode, the Z-SCC must be programmed to use 
the SDLC CRC polynomial, but the generator 
. and checker may be preset to all Is or all Os. 
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Figure 4. Detecting 5- or 7-Bit Synchronous Characters 
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The CRC is inverted before transmission and 
the receiver checks a.gainst the bit pattern 
0001110100001111. 
NRZ, NRZI or FM coding may be used in any 
lx mode. The parity options available in Asyn- 
chronous modes are available in Synchronous 
modes. 
The Z-SCC can be conveniently used under 
DMA control to provide high-speed reception 
or transmission. In reception, for example, the 
Z-SCC can interrupt the CPU when the first 
character of a message is received. The CPU 
then enables the DMA to transfer the message 
to memory. The Z-SCC then issues an end-of- 
frame interrupt and the CPU can check the 
status of the received message. Thus, the CPU 
is freed for other service while the message is 
being received. The CPU may also enable the 
DMA first and have the Z-SCC interrupt only 
on end-of-frame.This procedure allows all 
data to be transferred via the DMA. 
SOLe Loop Mode. The Z-SCC supports SDLC 
Loop mode in addition to normal SDLC. In an 
SDLC Loop, there is a primary controller 
station that manages the message traffic flow 
on the loop and any number of secondary 
stations. In SDLC Loop mode, the Z-SCC per- 
forms the functions of a secondary station 
while a Z-SCC operating in regular SDLC 
mode can act as a controller (Figure 5). 
A secondary station in an SDLC Loop is 
always listening to the messages being sent 
around the loop, and in fact must pass these 
messages to the rest of the loop by retrans- 
mitting them with a one-bit-time delay. The 
secondary station can place its own message 
on the loop only at speCific times. The con- 
troller signals that secondary stations may 
transmit messages by sending a special 
character, called an EOP (End Of Poll), 
around the loop. The EOP character is the bit 
pattern 11111110. Because of zero insertion 
during messages, this bit pattern is unique and 


~asily recognized. 
. When a secondary station has a message to 
transmit and recognizes an EOP on the line, it 


Figure S. An SDLe Loop 


changes the last binary 1 of the EOP to a 0 
before transmission. This has the effect of turn- 
ing the EOP into a flag sequence. The secon- 
dary station now places its message on the loop 
and terminates the message with an EOP. Any. 
secondary stations further down the loop with 
messages to transmit can then append their 
messages to the message of the first secondary 
station by the same process. Any secondary 
stations without messages to send merely echo 
the incoming messages and are prohibited 
from placing messages on the loop (except 
upon recognizing an EOP). 
SDLC Loop mode is a programmable option 
in the Z-SCC. NRZ, NRZI, and FM coding may 
all be used in SDLC Loop mode. 


Baud Rate Generator. Each channel in the 
Z-SCC contains a programmable baud rate 
generator. Each generator consists of two 8-bit 
time constant registers that form a 16-bit time 
constant, a 16-bit down counter, and a flip-flop 
on the output producing a square wave. On 
startup, the flip-flop on the output is set in a 
High state, the value in the time constant 
register is loaded into the counter, and the 
counter starts counting down. The output of 
the baud rate generator toggles upon reaching 
0, the value in the time constant register is 
loaded into the counter, and the process is 
repeated. The time constant may be changed 
at any time, but the new value does not take 
effect until the next load of the counter. 
The output of the baud rate generator may 
be used as either the transmit clock, the 
receive clock, or both. It can also drive the 
Digital Phase-Locked Loop (see next section). 
If the receive clock or transmit clock is not 
programmed to come from the TRxC pin, the 
output of the baud rate generator may be 
echoed out via the TRxC pin. 
The follOWing formula relates the time con- 
stant to the baud rate (the baud rate is in 
bits/second and the BR clock period is in 
seconds): 


baud rate = 
2 (time constant + 2) X (BR clock period) 


Digital Phase-Locked Loop. The Z-SCC con-. 
tains a Digital Phase-Locked Loop (DPLL) to 
recover clock information from a data stream 
with NRZI or FM encoding. The DPLL is driven 
by a clock that is nominally 32 (NRZI) or 16 
(FM) times the data rate. The DPLL uses this 
clock, along with the data stream, to construct 
a clock for the data. This clock may then be 
used as the Z-SCC receive clock, the transmit 
clock, or both. 
For NRZI encoding, the DPLL counts the 32x 
clock to create nominal bit times. As the 32x 
clock is counted, the DPLL is searching the 
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incoming data stream for edges (either 1 to a 
or a to 1). Whenever an edge is detected, the 
DPLL makes a count adjustment (during the 
next counting cycle), producing a terminal 
count closer to the center of the bit cell. 
For FM encoding, the DPLL still counts from 
a to 31, but with a cycle corresponding to two 
bit times. When the DPLL is locked, the clock 
edges in the data stream should occur between 
counts 15 and 16 and between counts 31 and 
O. The DPLL looks for edges only during a 
time centered on the 15 to 16 counting 
transition. 
The 32x clock for the DPLL can be pro- 
grammed to come from either the RTxC input 
or the output of the baud rate generator. The 
DPLL output may be programmed to be 
echoed out of the Z-SCC via the TRxC pin (if 
this pin is not being used as an input). 
Data Encoding The Z-SCC may be pro- 
grammed to encode and decode the serial data 
in four different ways (Figure 6). In NRZ 


encodi~g, a 1 is represented by a High level 
and a a is represented by a Low level. In NRZI 
encoding, a 1 is represented by no change in 
level and a a is represented by a change in 
level. In FMl (more properly, bi-phase mark) 
a transition occurs at the beginning of every 
bit cell. A 1 is represented by an additional 
transition at the center of the bit cell and a a is 
represented by no additional transition at the 
center of the bit cell. In FMO (bi-phase space), 
a transition occurs at the beginning of every 
bit cell. A a is represented by an additional 
transition at the center of the bit cell, and a 1 
is represented by no additional transition at 
the center of the bit cell. In addition to these 
four methods, the Z-SCC can be used to 
decode Manchester (bi-phase level) data by 
using the DPLL in the FM mode and program- 
ming the receiver for NRZ data. Manchester 
encoding always produces a transition at the 
center of the bit cell. If the transition is a to I, 
the bit is a O. If the transition is 1 to a the 
bit is a 1. 
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Auto Echo and Local Loopback. The Z-SCC 
is capable of automatically echoing everything 
it receives. This feature is useful mainly in 
Asynchronous modes, but works in Syn- 
chronous and SDLC modes as well. In Auto 
Echo mode, TxD is RxD. Auto Echo mode can 
be used with NRZI or FM encoding with no 
additional delay, because the data stream is 
not decoded before retransmission. In Auto 
Echo mode, the CTS input is ignored as a 
transmitter enable (although transitions on this 
input can still cause interrupts if programmed 
to do so). In this mode, the transmitter is 
actually bypassed and the programmer is 
responsible for disabling transmitter interrupts 
and WAIT/REQUEST on transmit. 
The Z-SCC is also capable of Local Loop- 
back. In this mode TxD is RxD, just as in Auto 
Echo mode. However, in Local Loopback 
mode, the internal transmit data is tied to the 
internal receive data and RxD is ignored 
(except to be echoed out via TxD). The CTS 
and DCD inputs are also ignored as transmit 
and receive enables. However, transitions on 
these inputs can still cause interrupts. Local 
Loopback works in Asynchronous, Syn- . 
chronous and SDLC modes with' NRZ, NRZIor 
FM coding of the data stream. 
1/0 Interface Capabilities. The Z-SCC offers 
the choice of Polling, Interrupt (vectored or 
nonvectored), and Block Transfer modes to 
transfer data, status, and control information to 
and from the CPU. The Block Transfer mode 
can be implemented under CPU or DMA 
control. 
Polling. All interrupts are disabled. Three 
status registers in the Z-SCC are automatically 
updated whenever any function is performed. 
For example, end-of-frame in SDLC mode 
sets a bit in one of these status registers. The 
idea behind polling is for the CPU to period- 
ically read a status register until the register 
contents indicate the need for data to be 
transferred. Only one register needs to be 
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read; depending on its contents, the CPU 
either writes data, reads data, or continues. 
Two bits in the register indicate the need for 
data transfer. An alternative is a poll of the 
Interrupt Pending register to determine the 
source of an interrupt. The status for both 
channels resides in one register. 
. 
Interrupts. The Z-SCC interrupt scheme con- 
forms to the Z-Bus specification. When a: 
Z-SCC responds to' an Interrupt Acknowledge 
signal (INTACK) from the CPU, an interrupt 
vector may be placed on the AID bus. This 
vector is written in WR2 and may be read in 
RR2A or RR2B (Figures 10 and 11). 
To speed interrupt response time, the Z-SCC 


. can modify three bits in this vector to indicate 
status. If the vector is read in Channel A, 
status is never included; if it is read in 
Channel B, status is always included. 
Each of the six sources of interrupts in the 


Z-SCC (Transmit, Receive, and External/Status 
interrupts in both channels) has three bits 
associated with the interrupt source: ,Interrupt 
Pending (IP), Interrupt Under Service (IUS), 
and Interrupt Enable (IE). Operation of the IE 
bit is straightforward. If the IE bit is set for a 
given interrupt source, then that source can 
request interrupts. The exception is when the 
MIE (Master Interrupt Enable) bit in WR9 is 
reset and no interrupts may be requested. The 
IE bits are write only. 
The other two bits are related to the Z-Bus 


interrupt priority chain (Figure 7). As a Z-Bus 
peripheral, the Z-SCC may request an ' 
interrupt only when no higher priority device 
is requesting one, e.g., when IEI is High. If 
the device in question requests an interrupt, it 
pulls down INT. The CPU then responds with 
INTACK, and the interrupting device places 
the vector on the AID bus. 
In the Z-SCC, the IP bit signals a need for 
interrupt servicing. When an IP bit is 1 and 
the IEI input is High, the INT output is pulled 
Low, requesting an interrupt. In the Z-SCC, if 
the IE bit is not set by enabling interrupts, 
then the IP for that source can never be set. 
The If> is set two or three AS cycles after the 
interrupt condition occurs. Two or three AS 
rising edges are required from the time an in- 
terrupt condition occurs until INT is activated. 
The IP bits are readable in RR3A. 
The IUS bits signal that an interrupt request 
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is being serviced. If an IUS is set, all interrupt 
sources of lower priority in the Z-SCC and 
external to the Z-SCC are prevented from 
requesting interrupts. The internal interrupt 
sources are inhibited by the state of the inter- 
nal daisy chain, while lower priority devices 
are inhibited by the lEO output of the Z-SCC 
being pulled Low and propagated to subse- 
quent peripherals. An IUS bit is set during an 
Interrupt Acknowledge cycle if there are no 
higher priority devices requesting interrupts. 
There are three types of interrupts: 
Transmit, Receive, and External/Status. Each 
. interrupt type is enabled under program con- 
trol with Channel A having higher priority 
than Channel B, and with Receiver, Transmit, 
and External/Status interrupts prioritized in 
that order within each channel. When the 
Transmit interrupt is enabled, the CPU is 
interrupted when the transmit buffer becomes 
empty. (This implies that the transrnitter must 
have had a data character written into it so 
that it can become empty.) When enabled, the 
receiver can interrupt the CPU in one of 
three ways: 
e Interrupt on First Receive Character or 
Special Receive Condition. 


e Interrupt on All Receive Characters or 
Special Receive Condition. 


e Interrupt on Special Receive Condition 


Only. 


Interrupt on First Character or Special Con- 
dition and Interrupt on SpeCial Condition Only 
are typically used with the Block Transfer 
mode. A Special Receive Condition is one of 


, the following: receiver overrun, framing error 


in Asynchronous mode, end-of-frame in SDLC 
mode and, optionally, a parity error. The 
Special Receive Condition interrupt is different 
from an ordinary receive character available 
interrupt only in the status placed in the vector 
during the Interrupt Acknowledge cycle. In 
Interrupt on First Receive Character, an inter- 
rupt can occur from Special Receive Condi- 
tions any time after the first receive character 
interrupt. 
The main function of the External/Status 
interrupt is to monitor the signal transitions of 
the CTS, DCD, and SYNC pins; however, an 
External/Status interrupt is also caused by a 
Transmit Under run condition, or a zero count 


Z·DUS 


PERIPHERAL 


Z·BUS 
PIZRIPHERAL 


lEI ADo-AD7 iNf INTACK lEO 
lEI ADo-AD7 iNf INTACK lEO 
lEI ADo-AD7 iNf INTACK 


+5V 


,+5V 


ADO-AD7\, ______________________________________________ 
~ 


INT.-------------~~--------------~~~--------------~~~ 


INTACK~--------------~----------------~~----------------~ 


Figure 7. Z-BUS Interrupt Schedule 
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in the baud rate generator, or by the detection 
of a Break (Asynchronous mode), Abort (SDLC 
mode) or EOP (SDLC Loop mode) sequence in 
the data stream. The interrupt caused by the 
Abort or EOP has a special feature allowing 
the Z-SCC to interrupt when the Abort or EOP 
sequence is detected or te~minated. This 
feature facilitates the proper termination of the 
current message, correct initialization of the 
next message, and the accurate timing of the 
Abort condition in external logic in SDLC 
mode. In SDLC Loop mode, this feature, allows 
secondary stations to recognize the wishes of 
the primary station to regain control of the 
loop during a poll sequence. 
CPU/DMA Block Transfer. The Z-SCG pro- 
vides a Block Transfer mode to accommodate 


The Z-SCC internal structure includes two 
full-duplex channels, two baud rate 
generators, internal control and interrupt 
logic, and a bus interface to the Zilog Z-Bus. 
Associated with each channel are a number of 


ADDRESS/~ 
DATA~ 


CPU 
BUS I/O 


CONTROL WL--__ 
...I 


INTERRUPT 
CONTROL 
LINES 
t t t 
+5 V GND PCLK 


INTERNAL 
CONTROL 
LOGIC 


INTERRUPT 
CONTROL 
LOGIC 


INTERNAL BUS 


CPU block transfer functions and DMA con- 
trollers. The Block Transfer mode uses the 
WAIT/REQUEST output in conjunction with the 
Wait/Request bits in WRI. The WAIT/ 
REQUEST output can be defined under soft- 
ware control as a WAIT line in the CPU Block 
Transfer mode or as a REQUEST line in the 
DMA Block Transfer mode. 
To a DMA controller, the Z-SCC REQUEST 


output indicates that the Z-SCC is ready to 
transfer data to or from memory. To the CPU, 
the WAIT line indicates that the Z-SCC is not 
ready to transfer data, thereby requesting that 
the CPU extend the I/O cycle. The DTRI 
REQUEST line allows full-duplex operation 
under DMA control. 


read and write registers for mode control and 
status information, as well as logic necessary to 
interface to modems or other external devices 
(Figure 8). 
The logic for both channels provides 


-I 
SERIAL DATA 
-I 
CHANNEL CLOCKS 


-SYNC 


=WA"""IT .... 
/R=EQ"'U""ES=T 


_ 
} 
MODEM, DMA, OR 
OTHER CONTROLS 


-} 
MODEM, DMA, OR 
• 
OTHER CONTROLS 


I 
SERIAL DATA 
-I 
CHANNEL CLOCKS 


SYNC 
WAIT/REQUEST 


Figure 8. Block Diagram of Z-SCC Architecture 
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CPU 1/0 


SOLc-eRC 
• I 
I CRC RESULT 
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Figuro 9. Data Path 
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Architecture 
(Continued) 
formats, synchronization, and validation for 
data transferred to and from the channel inter- 
face. The modem control inputs are monitored 
by the control logic under program control. 
All of the modem control signals are general- 
purpose in nature and can optionally be used 
for functions other than modem control. 
The register set for each channel includes 
ten control (write) registers, two sync 
character (write) registers, and four status 
(read) registers. In addition, each baud rate 
generator has two (read/write) registers for 
holding the time constant that d6cermines the 
baud rate. Finally, associated with the inter- 
rupt logic is a write register for the interrupt 
vector accessible through either channel, a 
write-only Master Interrupt Control register 
and three read registers: one containing the 
vector with status infomation (Channel B only), 
one containing the vector without status 
(Channel A only), and one containing the 
Interrupt Pending bits (Channel A only). 
The registers for each channel are 
designated as follows: 


WRO-WRl5 - 
Write Registers 0 through 15. 
RRO-RR3, RRlO, RR12, RR13, RR15 - 
Read 
Registers 0 through 3, 10, 12, 13, 15. 
Table 1 lists the functions assigned to each 
read or write register. The Z-SCC contains 
only one WR2 and WR9, but they can be 
accessed by either channel. All other registers 
are paired (one for each channel). 
Data Path. The transmit and receive data path 
illustrated in Figure 9 is identical for both 
channels. The receiver has three 8-bit buffer 
registers in an FIFO arrangement, in addition 
to the 8-bit receive'shift register. This scheme 
creates additional time for the CPU to service 
an interrupt at the beginning of a block of 
high speed data. Incoming data is routed 
through one of several paths (data or CRC) 
depending on the selected mode (the character 
length in Asynchronous modes also determines 
the data path). 
The transmitter has an 8-bit Transmit Data 


Programming 
The Z-SCC contains 13 write registers in 
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each channel that are programmed by the 
'system separately to configure the functional 
personality of the channels. All of the registers 
in the Z-SCC are directly addressable. How 
the Z-SCC decodes the address placed on the 
address/data bus at the beginning of a Read or 
W rite cycle is controlled by a command issued 
'in WROB. In the Shift Right mode the channel 
select AlB is taken from ADo and the state of 
ADs is ignored. In the Shift Left mode A/B is 
taken from Aps and the state of ADo is 


I 
buffer register loaded from the internal data 
bus and a 20-bit Transmit Shift register that 
can be loaded either from the synchronous 
character registers or from the Transmit Data 
register. Depending on the operational mode, 
outgoing data is routed through one of four 
main paths before it is transmitted from the 
Transmit Data output (TxD) 


Read Register Functions 


RRO 
Transmit/Receive buffer status and External status 


RRI 
Special Receive Condition status 


RR2 
Modified interrupt vector (Channel B only) , 
Unmodified interrupt vector (Channel A only) 


RR3 
Interrupt Pending bits (Channel A only) 


RR8 
Receive buffer 


RRIO 
Miscellaneous status 


RR12 
Lower byte of baud rate generator time constant 


RR13 
Upper byte of baud rate generator time constant 


RRlS 
External/Status interrupt information 


Write Register Functions 


WRO 
CRC initialize, initialization commands for the 
various modes, shift right/shift left command 


WRI 
Transmit/Receive interrupt and data transfer mode 
definition 


WR2 


WR3 


WR4 


WRS 


WR6 


WR7 


WR8 


Interrupt vector (accessed through either channel) 


Receive parameters and control 


Transmit/Receive miscellaneous parameters and 
modes 


Transmit parameters and controls 


Sync characters or SOLC address field 


Sync character or SOLC flag 


Transmit buffer 


WR9 
Master interrupt control and reset (accessed 
through either channel) 


WRIO 
Miscellaneous transmitter/receiver control bits 
WRll 
Clock mode control 


WR12 
Lower byte of baud rate generator time constant 


WR13 
Upper byte ~f baud rate generator time constant 


WR14 . Miscellaneous control bits 


WRlS 
External/Status interrupt control 


Table I. Read and Write Register Functions 


ignored. AD7 and AD6 are always ignored as 
address bits and the register address itself 
occupies AD4-ADl. 
The system program first issues a series of 
commands to initialize the basic mode of 
operation. This is followed by other commands 
to qualify conditions within the selected mode. 
For example, the Asynchronous mode, 
character length, clock rate, number of stop 
bits, even or odd parity might be set first. 
Then the Interrupt mode would be set, and 
finally, receiver or transmitter enable. 


Programming 
(Continued) 
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Read Registers. The Z-SCC contains eight 
read registers (actually nine, counting the 
receive buffer [RR8]) in each channel. Four of 
these may be read to obtain status information 
(RRO, RRl, RRlO, and RR15). Two registers 
(RR12 and RR13) may be read to learn the 
baud rate generator time constant. RR2 con- 
tains either the unmodified interrupt vector 
(Channel A) or the vector modified by status 
information (Channel B). RR3 contains the 


Read Register 0 
~ 


I ~ 
~~~~:.~::::"u'" 
~SYNC/HUNT 


CTS 


Tx UNDERRUN/EOM 
'-------- BREAK/ABORT 


Read Register 1 


I 0, I 0,1 Os I 0.1 0,1 021 0, I Do I 
~~ 


I ~ 
:~~I:~:TCODE.2 
LS 
RESIDUE CODE 1 


RESIDUE CODE 0 


PARITY ERROR 


Rx OVERRUN ERROR 


CRC/FRAMING ERROR 
'--------- END OF FRAME (SOLC) 


Read Register 2 


INTERRUPT VECTOR' 


'-------------V7 


'MODIFIED IN B CHANNEL 


Read Register 3 


~~ 


I ~ 
~:::::~:~::~S.TATIP' 
L 
CHANNEL B Rx IP' 


CHANNEL A EXT/STAT IP' 


CHANNEL A Tx IP' 


CHANNEL A Rx IP' 
o 


'--------------- 0 


'ALWAYS 0 IN B CHANNEL 


Interrupt Pending (IP) bits (Channel A). 
Figure 10 shows the formats for each read 
register. 
The status bits of RRO and RRI are carefully 
grouped to simplify status monitoring; e:g., 
when the interrupt vector indicates a Special 
. Receive Condition interrupt, all the appro- 
priate error bits can be read from a Single 
register (RRl)., 


Read Register 10 


L...-___________ ONE CLOCK MISSING 


Read Register 12 


'-------- TC7 


Read Register 13 


10, I 0,1 Os 10.10,1 021 0, I Do I 


~:~:~ 
'-------- TC'5 


Read Register 15 


I~I~I~I~I~I~I~I~I 


LOWER BYTE OF 
TIME CONSTANT 


UPPER BYTE OF 
TIME CONSTANT 


~~ 


~~'O'O""" 
CDCDIE 


SYNC/HUNT IE 


CTS IE 


Tx UNDERRUN/EOM IE 
'-------- BREAK/ABORT IE 


Figure 10. Read Register Bit Functions 
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Write Registers. The Z-SCC contains 13 write 
registers (14 counting WR8, the transmit 
buffer) in each channel. These write registers 
are programmed separately to configure the 
functional "personality" of the channels, In 
addition, there are two registers (WR2 and 


Write Register 0 
1 


0 
0 
NULL CODE 


o 
1 
NULL CODE 


1 
0 
SELECT SHIFT LEFT MODE' 


1 
1 . :ELECT SHIFT RIGHT MODE' 


o 
0 
0 
NULL CODE 


o 0 
1 
NULL CODE 


o 1 
0 
RESET EXT/STATUS INTERRUPTS 


o 1 
1 
SEND ABORT 


1 
0 
0 
ENABLE INT ON NEXT Rx CHARACTER 


1 
0 
RESET Tx INT PENDING 


1 
1 
ERROR RESET 


1 
1 
1 
RESET HIGHEST IUS 


o 
0 
NULL CODE 


o 1 
RESET Rx CRC CHECKER 


1 
0 
RESET Tx CRC GENERATOR 


1 
1 
RESET Tx UNDERRUN/EOM LATCH 


'B CHANNEL ONLY 


Write Register 1 


I~I~I~I~I~I~I~I~I 
I I L "" '"",,'" 
L 
Tx INT ENABLE 


PARITY IS SPECIAL CONDITION 


o 
0 
Rx INT DISABLE 


o 
1 
Rx INT ON FIRST CHARACTER OR SPECIAL CONDITION 


1 
OINT ON ALL Rx CHARACTERS OR SPECIAL CONDITION 


1 
1 
Rx INT ON SPECIAL CONDITION ONLY 
'------ WAIT/DMA REQUEST ON RECEIVE/TRANSMIT 
1-------- WAIT/DMA REQUEST FUNCTION 
1--------- WAIT/DMA REQUEST ENABLE 


Write Register 2 


I 0,1 0.1 0,1 0.1 0,1 0,1 0, I 
Do I 
mi: 


INTERRUPT VECTOR 


1--------- V7 


WR9) shared by the two channels that may be 
accessed through either of them, WR2 contains 
the interrupt vector for both channels, while 
WR9 contains the interrupt control bits, Figure 
11 shows the format of each write register, 


Write Register 3 


~~ 


L-.: Rx ENABLE 


SYNC CHARACTER LOAD INHIBIT 


ADDRESS SEARCH MODE (SDLC) 


Rx CRC ENABLE 


ENTER HUNT MODE 


AUTO ENABLES 


o 
0 
Rx 5 BITS/CHARACTER 


o 
1 
Rx 7 BITS/CHARACTER 


1 
0 
Rx 6 BITS/CHARACTER 


1 
1 
Rx 8 BITS/CHARACTER 


Write Register 4 


I 0,1 0: I 0,1 0.1 OJ I D,I 0, I Do I 


~ 


I L PARITY ENABLE 
L 
PARITY EVEN/ODD 


o 
0 
SYNC MODES ENABLE 
o 
1 
1 S70P BIT/CHARACTER 


1 
0 
1 '12 STOP BITS/CHARACTER 


1 
1 
2 STOP BITS/CHARACTER 


o 
0 
8 BIT SYNC CHARACTER 
o 
1 
16 BIT SYNC CHARACTER 
o 
SDLC MODE (01111110 FLAG) 


1 
1 
EXTERNAL SYNC MODE 


o 0 
X 1 CLOCK MODE 


o 1 
X16 CLOCK MODE 


1 
0 
X32 CLOCK MODE 


1 
1 
X64 CLOCK MODE 


Write Register 5 


,~I 
L-.: :;SCRC ENABLE 
L 
SOLC/CRC.16 


Tx ENABLE 


SEND BREAK 


o 
0 
Tx 5 BITS (OR LESS)/CHARACTER 


o 
1 
Tx 7 BITS/CHARACTER 


1 
0 
Tx 6 BITS/CHARACTER 


1 
1 
Tx 8 BITS/CHARACTER 
'-------- DTR 


Write Register 6 


I 0,1 061 0,1 0.1 OJ I 0,1 0, I 
Do I 
IFP)~~ 


SYNC7 
SYNCs 
SYNC, 
SYNC, 
SYNC3 
SYNC2 
SYNC, 
SYNCo 
MONOSYNC, 8 BITS 
SYNC, 
SYNCo 
SYNCs 
SYNC, 
SYNC3 
SYNC2 
SYNC, 
SYNCo 
MONOSYNC, 6 BITS 
SYNC7 
SYNCs 
SYNCs 
SYNC, 
SYNC3 
SYNC2 
SYNC, 
SYNCo 
BISYNC, 16 BITS 
SYNC3 
SYNC2 
SYNC, 
SYNCo 
1 
1 
1 
1 
BISYNC, 12 BITS 


ADR7 
ADRa 
ADRs 
ADR, 
ADR3 
ADR2 
ADR, 
ADRo 
SDLC 


ADR7 
ADRs 
ADRs 
ADR, 
SDLC (ADDRESS RANGE) 


Figure 11. Write Register Bit Functions 
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Write Register 1 


Write Register 9 


I 0,1 0,1 051 0.1 031 0,1 0, I 
Do I 


SYNC, 
SYNCs 
SYNC1S 
SYNC11 
o 


L 
DLC 


MIE 


SYNCS 
SYNC4 
SYNC14 
SYNC10 


1 


SYNCs 
SYNC3 
SYNC13 
SYNC9 


1 


~~ 


~~~ 


:TATUS HIGHISTATUS LOW 


o 
0 
NO RESET 
o 
1 
CHANNEL RESET B 


1 
0 
CHANNEL RESET A 


1 
1 
FORCE HARDWARE RESET 


Write Register 10 
I 071 0,1 05 1 0.1 031 0,1 0, I 
Do I 
~ 


I ~ 
6 BIT/a BIT SYNC 
LLOOPMODE 


ABORT/FLAG ON UNDERRUN 


MARK/FLAG IDLE 


GO ACTIVE ON POLL 


o 
0 
NRZ 
o 
1 
NRZI 


1 
0 
FM1 (TRANSITION = 1) 


1 
1 
FMO (TRANSITION = 0) 


1..-_______ CRC PRESET 110 


Write Register 11 


I 07 
1 D,I D51 D.I D31 D,I D, IDol 


o 
1 
TRxC OUT = TRANSMIT CLOCK 


SYNC4 
SYNC2 
SYNC12 
SYNCa 


1 


~ 


o 
0 
TRxC OUT = XTAL OUTPUT 


1 
0 
TRxC OUT = BR GENERATOR OUTPUT 


1 
1 
TRxC OUT = DPLL OUTPUT 


TRxC 011 


o 
0 
TRANSMIT CLOCK = RTxC PIN 


o 
1 
TRANSMIT CLOCK = TRxC PIN 


1 
0 
TRANSMIT CLOCK = BR GENERATOR OUTPUT 


1 
1 
TRANSMIT CLOCK = DPLL OUTPUT 


o 
0 
RECEIVE CLOCK = RTxC PIN 


o 
1 
RECEIVE CLOCK = TRxC PIN 


1 
0 
RECEIVE CLOCK = BR GENERATOR OUTPUT 


1 
1 
RECEIVE CLOCK = DPLL OUTPUT 


~--------RTxCXTAUNOXTAL 


SYNC3 
SYNC1 
SYNC11 
SYNC, 


1 


SYNC2 
SYNCo 
SYNC10 
SYNCs 


1 


x 


SYNC9 
SYNCs 


1 


X 
SYNCa 
SYNC4 
o 


MONOSYNC, a BITS 
MONOSYNC, 6 BITS 
[lISYNC, 16 BITS 
BISYNC, 12 BITS 
SDLC 


Write Register 12 


LOWER BYTE OF 
TIME CONSTANT 


1..-________ TC, 


Write Register 13 


UPPER BYTE OF 
TIME CONSTANT 


1..-_______ TC1S 


Write Register 14 


0 
0 
0 


0 
0 
1 


0 
1 
0 


0 
1 
1 


1 
0 
0 


1 
0 
1 


1 
1 
0 


1 
1 
1 


~~ 


L DR GENERATOR ENABLE 
L. 
BR GENERATOR SOURCE 


DTR/REQUEST FUNCTION 


AUTO ECHO 


LOCAL LOOPBACK 


NULL COMMAND 


ENTER SEARCH MODE 


RESET MISSING CLOCK 


DISABLE DPLL 


SET SOURCE = BR GENERATOR 


SET SOURCE = RTxC 


SET FM MODE 


SET NRZI MODE 


Write Register 15 


I~I~I~I~I~I~I~I~I 


~~;;:::::' 


Tx UNDERRUN/EOM IE 
1..-________ BREAK/ABORT IE 


Figure 11. Write Rogister Bit FUDctions (Continued) 
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The Z-SCC generates internal control signals 
from AS and DS that are related to PCLK. 
Since PCLK has no phase relationship with 
AS and DS, the circuitry generating these 
internal control signals must provide time for 
metastable conditions to disappear. This gives 
rise to a recovery time related to PCLK. The 
recovery time applies only between bus trans- 
actions involving the Z-SCC. The recovery 
time required for proper operation is specified 
from the rising edge of DS in the first transac- 
tion involving the Z-SCC to the falling edge of 


I 


DS in the second transaction involving the 
Z-SCC. This time must be at least 6 PCLK 
cycles plus 200 ns. 
Read Cycle Timing. Figure 12 illustrates read 
cycle timing. The address on ADo-AD7 and· 
the state of CSo and INTACK are latched by 
the rising edge of AS. R/W must be High to 
indicate a Read cycle. CSI must also be High 
for the Read cycle to occur. The data bus 
drivers in the Z-SCC are then enabled while 
DS is Low. 


INTACK 
/ 
--- 
\_--------~----------- 


ADO-AD7 
X 
ADDRESS ) 
( 
X DATA VALID 
}-- 
------ 


R1W 
7 
7 
c 


\~ ____ 
~r- 


Flguro 12. Road Cyclo Timing 


Write Cycle Timing. Figure 13 illustrates 
Write cycle timing. The address on ADo-AD7 
and the state of CSo and INTACK are latched 
by the rising edge of AS. R!W must be Low to 


, 
, 


\ 
I 
CSo 


7 
\ 


indicate a Write cycle. CSI must be High for 
the Write cycle to occur. DS Low strobes the 
data into the Z-SCC. 


ADO-AD7 
X 
ADDRESS XJ( 
DATA 
~ 
______ X= 


RIW _______ 
\~ 
___________ ...&r_ 


cs1 ______ 7 
C 


\ _______ ....Jr-' 


Figure 13. Write Cycle Timing 


Interrupt Acknowledge Cycle Timing. 
Figure 14 illustrates Interrupt Acknowledge 
cycle timing. The address on ADo-AD 7 and 
the state of CSo and INTACK are latched by 


the rising edge of AS. However, if INTACK is 
Low, the address and CSo are ignored. The 
state of the R/W and CSI are also ignored for 
the duration of the Interrupt Acknowledge 


2016-007, 008 


Timing 
(Continued) 


::ycle. Between the rising edge of AS and the 
falling edge of DS, the internal and external 
lEI/lEO daisy chains settle. If there is an inter- 
rupt pending in the Z-SCC and lEI is High 
when DS falls, the Acknowledge cycle was 


CSo 
X 


(IGNORED) X 


INTACK 
~ 
L 


ADo-AD7 
X 


(IGNORED) ) 


os 


; 
.I' 


~ 
, 


I) 


'I 


intended for the Z-SCC. In this case, the 
Z-SCC may be programmed to respond to DS 
Low by placing its interrupt vector on 
ADo-AD7. It then sets the appropriate 
Interrupt-Under-Service latch internally. 


CJ< 
VECTOR >- 


Figuro 14. Intorrupt Aclcnowlodgo Cyclo Timing 


Absolute 
Maximum 
Ratings 


Standard 
Test 
Conditions 


DC 
Charac- 
teristics 


Voltages on all inputs and outputs 
with respect to GND .......... -0.3 V to + 7.0 V 
Operating Ambient 
Temperature ................. As Specified in 
Ordering Information 


Storage Temperature ........ -65°C to + 150 °C 


The characteristics below apply for the 
follOWing standard test conditions, unless 
otherwise noted. All voltages are referenced to 
GND. Positive current flows into the refer- 
enced pin. Standard conditions are as follows: 


+5V 


2.1K 


Figure 15. Standard Test Load 


Symbol 
Parameter 
Min 


VIH 
Input High Voltage 
2.0 


VIL 
Input Low Voltage 
-0.3 


VOH 
Output High Voltage 
2.4 


VOL 
Output Low Voltage 


IlL 
Input Leakage 


IOL 
Output Leakage 
Icc 
Vee Supply Current 


Stresses greater than those listed under Absolute Maxi- 
mum Ratings may cause permanent damage to the device. 
This is a stress rating only; operation of the device at any 
condition above those indicated in the operational sections 
of these specifications is not implied. Exposure to absolute 
maximum rating conditions for extended periods may affect 
device reliability. 


[J +4.75 V ::5 Vee ::5 +5.25 V 


fJ GND = 0 V 


[J TA as specified in Ordering Information 
All ac parameters assume a load capacitance 
of 50 pF max. 


Max 


Vee+ 0.3 
0.8 


0.4 


± 10.0 
± 10.0 
250 


, 
+5V 


FROM OUTPUT 
UNDER TEST ~ 


2'2K 
r 
50pF 


Figure 16. Open-Drain Test Load 


Unit 


V 
V 
V 
V 
p.A 
p.A 
rnA 


Condition 


IOH = -250 p.A 
1oL= +2.0 rnA 
0.4 =::; VIN =::; + 2.4V 
0.4 =::; Your =::; +2.4V 


Vee = 5 V ± 5% unless otherwise specified, over speCified temperature range. 


Capacitance 
Symbol 


CIN 
COUT 
Cvo 


Parameter 


Input Capacitance 
Output Capacitance 
Bidirectional Capacitance 


f = I MHz, over speCified temperature range. 


20 \6-009 
8085-006, 00 I 


Min 
Max 


10 
15 
20 


Unit 


pF 
pF 
pF 


Test Condition 


U nrneasured Pins 
Returned to Ground 
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Read and 
Write 
Timing 


CSo 


RlW 
READ ____ -++-_.1 


RIW 


WRITE ----~H_---_+_-+----------__+---"Ij_---------- 


ADo-AD7 


WRITE ___ 1'--+-!---1 


ADo-AD7 


READ __ 
--' 1'--Hf----"rr 


WIREQ 


WAIT 


WIREQ 


REQUEST _____ -+-_____ -+ ___ --' 


DTRlREQ 
REQUEST _____ -+-_____________________ _ 


~---~~~----~~-------------------------~ 


4 MHz 
No. 
Symbol 
Parameter 
Min 
Max 


1 
TwAS 
AS Low Width 
70 


2 
TdDS(AS) 
DS t to AS • Delay 
50 


3 
TsCSO(AS) 
CSo to AS t Setup Time 
a 
4 
ThCSO(AS) 
CSo to AS t Hold Time 
60 
100 
55 
5 -TsCSl(DS) --CS1 to DS l Setup Time---------- 
6 
ThCSl(DS) 
CS] to iSS tJiold Time 
7 
TsIA(AS) 
INTACK to AS t Setup Time 
a 
8 
ThIA(AS) 
INTACK to AS t Hold Time 
250 
100 
55 
9 
TsRWR(DS) 
RiW (Read) to DS • Setup Time 
lO-ThRW(DS)--RiWto DS t Hold Time ---------- 
11 
TsRWW(DS) 
RiW (Write) to DS l Setup Time 
a 
12 
TdAS(DS) 
AS t to DS • Delay 
60 


13 
TwDSl 
DS Low.Width 
390 


14 
TrC 
Valid Access Recovery Time 
6TcPC 
+200 


15 - 
TsA(AS) 
Address to AS t Setup Time --------- 30 


16 
ThA(AS) 
Address to AS t Hold Time 
50' 


17 
TsDW(DS) 
Write Data to DS , Setup Time 
30 


18 
ThDW(DS) 
Write Data to DS t Hold Time 
30 


19 
TdDS(DA) 
DS , to Data Active Delay 
a 


20-TdDSr(DR)--DS t to Read Data Not Valid Delay------- a 
21 
TdDSf(DR) 
DS , to Read Data Valid Delay 
250 


22 
TdAS(DR) 
AS t to Read Data Valid Delay 
520 


6 MHz 
Min 
Max 


50 
25 
a 
40 


Notes*t· 


1 
1 


80 ------,,....----1- 
40 
1 
a 


250 
80 
40 
a 
40 
250 
6TcPC 
2 
+ 130 


10 ---,....----1- 
30 
1 


20 
20 
a 
a 


180 
335 


NOTES: 
1. Parameter does not apply to Interrupt Acknowledge 
transactions. 


2. Parameter applies only between transactions involving the sec. 
'Timings are preliminary and subject to change. 
, 
tUnits in nanoseconds (ns). 
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Interrupt 
Acknowledge 
Timing 


Reset 
Timing 


Cycle 
Timing 


y 


----------------~ 


ADo-AD7 ----------------------I---------------++--~ 


lEI 


lEO 


t-----{36}---l~ }--------------- 


PCLf( 


4MHz 
6 MHz 
No. 
Symbol 
Parameter 
Min 
Max 
Min 
Max 
Notes*t 


23 
TdDS(DRz) 
DS t to Read Data Float Delay 
70 
45 
24 
TdA(DR) 
Address Required Valid to Read Data Valid Delay 
570 
420 


25 
TdDS(W) 
DS l to Wait Valid Delay 
240 
200 


26 
TdDSf(REQ) 
DS l to W/REQ Not Valid Delay 
240 
200 
27-TdDSr(REQ)-DS t to DTRlREQ Not Valid Delay--------- 5TcPC 
5TcPC 
+300 
+250 


28 
TdAS(INT) 
AS t to INT Valid Delay 
500 
500 


29 
TdAS(DSA) 
AS t to DS l (Acknowledge) Delay 
250 
250 
30 
TwDSA 
DS (Acknowledge) Low Width 
390 
250 


31 
TdDSA(DR) 
DS l (Acknowledge) to Read Data Valid Delay 
250 
180 


32 - 
TsIEI(DSA) -- lEI to DSl (Acknowledge) Setup Time ----- 120 
100 


33 
ThIEI(DSA) 
lEI to DS t (Acknowledge) Hold Time 
0 
0 


34 
TdIEI(lEO) 
lEI to lEO Delay 
120 
100 


35 
TdAS(lEO) 
AS t to lEO Delay 
250 
250 


36 
TdDSA(INT) 
DS·l (Acknowledge) to INT Inactive Delay 
500 
500 


37 - 
TdDS(ASQ) -- DS t to AS l Delay for No Reset -------- 30 
15 
38 
TdASQ(DS) 
AS t to DS l Delay for No Reset 
30 
30 


39 
TwRES 
AS and DS Coincident Low for Reset 
250 
250 
40 
TwPCl 
PCLK Low Width 
105 
2000 
70 
1000 


41 
TwPCh 
PCLK High Width 
105 
2000 
70 
1000 
42-TcPC 
PCLK Cycle Time ------------ 250 -4000--165- 2000 


43 
TrPC 
PCLK Rise Time 
20 
15 
44 
TfPC 
PCLK Fall Time 
20 
10 


NOTES: 


3 


4 


4 
5 


6 
4 


7 


3. Float delay is defined as the time required for a ±0.5 V change 
in the output with a maximum dc load and minimum ac load. 
4. Open-drain output, measured with open-drain test load. 
5. Parameter is system dependent. For any Z-SCC in the daisy 


chain, TdAS(DSA) must be greater than the sum of TdAS(IEO) 
for the highest priority device in the daisy chain, TsIEI(DSA) 


6. Parameter applies only to a Z-SCC pulling INT Low at the 
beginning of the Interrupt Acknowledge transaction. 
7. Internal circuitry allo;""s for the reset provided by the Z8 to be 
recognized as a reset by the Z-SCC . 


for the Z-SCC, and TdIEIf(IEO) for each device separating them 
in the daisy chain. 


2016-011, 012, 013 


• Timings are preliminary and subject to change. All timing refer- 


ences assume 2.0 V for a logic "I" and 0.8 V for a logic "0". 


t Units in nanoseconds (ns). 
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General 
Timing 
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PCLK 


WIRE::Q 
REQUEST 


WIREQ 
WAIT ________________________ +-____________________________ --' 


RTxC, TRxC 
RECEIVE ____________ ..;... ____ ~ I 


RxD 


SYNC 


EXTERNAL __________ J~~ 
__________ +_------------~'~------------------------------------------ 


TRxC,RTxC 


TRANSMIT 


TxD ---CI-: ___ ..,...--" _______ ~ '__ ___ _ 
___ 
'~ 
___ 
®_'3~_-_-__ 
~:~ 


TRxC 
~--------------------------------------------------- 
OUTPUT ___________________________ ~ ~ __________________________________________________ __ 
\----D7Jg 


TRXC-----\~ __ ~~-----\~-----'r- 


m,DCD 
~ 
I 
---, 
~r.:==®==J . 


SYNC 
~ 
/'-------------------------------- 
INPUT 
- 
. 


----------------- 
22· F=®===i 


2016-014 


No. 
Symbol 
Parameter 


1 
TdPC(REQ) 
PCLK l to W IREQ Valid 


2 
TdPC(W) 
PCLK l to Wait Inactive Delay 


3 
TsRXC(PC) 
RxC t to PCLK t Setup Time (PCLK 


4 
TsRXD(RXCr) 
RxD to RxC t Setup Time (Xl Mode) 
5-ThRXD(RXCr)-RxD to RxC t Hold Time (Xl Mode) 


6 
TsRXD(RXCf) 
RxD to RxC l Setup Time (Xl Mode) 


7 
ThRXD(RXCf) 
RxD to RxC l Hold Time (Xl Mode) 


8 
TsSY(RXC) 
SYNC to RxC t Setup Time 


9 
ThSY(RXC) 
SYNC to RxC t Hold Time 


10 -TsTXC(PC)--TxC l to PCLK t Setup Time 


11 
TdTXCf(TXD) 
TxC I to TxD Delay (Xl Mode) 


12 
TdTXCr(TXD) 
TxC t to TxD Delay (Xl Mode) 


13 
TdTXD(TRX) 
TxD to TRxC Delay (Send Clock Echo) 


14 
TwRTXh 
RTxC High Width 
15-TwRTXl 
RTxC Low Width 


16 
TcRTX 
RTxC Cycle Time 


17 
TcRTXX 
Crystal Oscillator Period 


18 
TwTRXh 
TRxC High Width 


19 
TwTRXl 
TRxC Low Width 
20-TcTRX 
TRxC Cycle Time 


21 
TwEXT 
DCD or CTS Pulse Width 


22 
TwSY 
SYNC Pulse Width 


NOTES: 
1. RxC is RTxC or TRxC, whichever is supplying the receive 
clock. 
2. TxC is TRxC or RTxC, whichever is supplying the transmit 
clock. 
3. Both RTxC and SYNC have 30 pf capacitors to the ground 
connected to them. 
4. Parameter applies only if the data rate is one-fourth the PCLK 


rate. In all other cases, no phase relationship between RxC and 
PCLK or TxC and PCLK is required. 


4MHz 
6 MHz 
Min 
Max 
Min 
Max 
Notes*t 


250 
250 


350 
350 


4 case only) 
dO 
TwPCL 
70 
TwPCL 
1,4 


0 
0 


150 
150 
I- 


0 
0 
I,S 


150 
150 
1,5 


-200 
-200 
1 


3TcPC 
3TcPC 
+200 
+200 


0 
0 
2,4- 


300 
300 
2 


300 
300 
2,5 


200 
200 


180 
180 
6 


180 
180 
6- 


400 
400 
6 


250 
1000 
250. 
1000 
3 


180 
180 
6 


180 
180 
6 


400 
400 
6- 


200 
200 


200 


5. Parameter applies only to FM encoding/decoding. 
6. Parameter applies only for transmitter and receiver; DPLL and 
baud rate generator timing requirements are ideniical to chip 
PCLK requirements. 
* Timings are preliminary and subject to change. 
t Units in nanoseconds (ns). 
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lSI 
Oft e 
W 
0 


~ 
~ 
8 


System 
Timing 
RfiC, TiiiC 
RECEIVE 


W/REQ 


REQUEST 


W/REQ 


WAIT 


SYNC 


OUTPUT 


RTJlC, TRJlC 


TRANSMIT 


W/REQ 


REQUEST 


W/REQ 


WAIT, 


DTRlREQ 


REQUEST 


CTS, DCD 
V 
------------~~~~------------------------- 


SYNC--------------------~----~J(~------------------------------------- 
INPUT 


----------------~--~~~~9----~-------------------- 


INT--------------~~-----------\ 


~--____(IO)_---'i~ 


-------,------------------------------------------------------------------------------------- 


No. 
Symbol 


2 
3 


4 


TdRXC(REQ) 


TdRXC(W) 


TdRXC(SY) 


TdRXC(INT) 


Parameter 


RxC t to VI/REQ Valid Delay 


RxC t to Wait Inactive Delay 


RxC t to SYNC Valid Delay 


RxC t INT Valid Delay 


Min 


8 
8 
4 
8 
+2 


4 MHz 
Max 


12 


12 


7 
12 
+3 


5 -TdTXC(REQ) -TxC I to W IREQ Valid Delay -------- 5--8 


6 
TdTXC(W) 
TxC I to Wait Inactive Delay 


7 
TdTXC(DRQ) 
TxCI tb DTR/REQ Valid Delay 


8 
TdTXC(INT) 
TxC I to INT Valid Delay 


9 


10 


NOTES: 


TdSY(INT) 


TdEXT(INT) 


SYNC Transition to INT Valid Delay 


DCD or CTS Transition to INT Valid Delay 


1. Open·drain output, measured with open-drain test load. 


5 
8 
4 
7 
4 
6 
+2 
+3 
2 
3 
2 
3 


4. Units equal to TcPC. 
5. Units equal to AS. 


6 MHz 
Min 
Max 


8 
12 
8 
12 
4 
7 
8 
12 
+2 
+3 
5--8 


5 
8 
4 
7 
4 
6 
+2 
+3 
2 
3 
2 
3 


2. RxC is RTxC or TRxC, whichever is supplying the receive 
clock. 
·'Timings are preliminary and subject to change. 
3. TxC is TRxC or RTxC, whichever Is supplying the transmit 
clock. 
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Notes* 


2,4 
1,2,4 
2,4 
1,2,4 
5 
3,4- 
1,3,4 
3,4 
1,3,4 
5 
1,5 
1,5 
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Ordering 
Product 
Package/ 
Product 
Package/ 
Information 
Number 
Temp 
Speed 
Description 
Number 
Temp 
Speed 
Description 


Z8030 
CE 
4.0 MHz 
Z-SCC (40-pin) 
Z8030A 
CE 
6.0 MHz 
Z-SCC (40-pin) 


Z8030 
CM 
4.0 MHz 
Same as above 
Z8030A 
CM 
6.0 MHz 
Same as above 


Z8030 
CMB 
4.0 MHz 
Same as above 
Z8030A 
CMB 
6.0 MHz 
Same as above 


Z8030 
CS 
4.0 MHz 
Same as above 
Z8030A 
CS 
6.0 MHz 
Same as above 


Z8030 
DE 
4.0 MHz 
Same as above 
Z8030A 
DE 
6.0 MHz 
Same as above 


Z8030 
DS 
4.0 MHz 
Same as above 
Z8030A 
DS 
6.0 MHz 
Same· as above 


Z8030 
PE 
4.0 MHz 
Same as above 
Z8030A 
PE 
6.0 MHz 
Same as above 


Z8030 
PS 
4.0 MHz 
Same as above 
Z8030A 
PS 
6.0 MHz 
Same as above 


. NOTES: C = Ceramic, D = Cerciip, P = Plastic; E = -40°C to +85°C, M = -55°C to 125°C, MB = -55°C to 125°C with MIL-STD-883 
with Class B processing, S = O°C to.+70°C. 


00·2016-02 
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Zilo 


Features 


General 
Description 


2245-001, 002 


Ell Two independent, 0 to 1M biVsecond, full- 
duplex channels, each with a separate 
crystal oscillator and baud rate generator. 


iii Programmable for NRZ, NRZI, or FM data 
encoding. 


m Local Loopback and Auto Echo modes. 


The 28031 Z-ASCC Asynchronous Serial 
Communications Controller is a dual-channel 
data communications peripheral designed for 
use with the Zilog Z-BUS. The Z-ASCC func- 
tions as a serial-to-parallel, parallel-to-serial 
converter/controller. The device contains a 
variety of new, sophisticated internal functions 
including on-chip baud rate generators and 
crystal oscillators that dramatically reduce the 
need for external logic. 
The Z-ASCC has facilities for modem con- 


_ 
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7 


_ 


AD 


6 


ADs 


TxDA 


RxDA 


TRxCA 


RTxCA 


} SERIAL 


DATA 


} CHANNEL 


CLOCKS 
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·CH·A 


AD, 
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TIMING 
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I 


iNr 


INTACK 
INTERRUPT 
lEI 


lEO 
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Figure 1. Pin Functions 


CHANNEL 
CONTROLS 
FOR MODEM, 
DMA,OR 
OTHER 


} SERIAL 


DATA 


} CHANNEL 


CLOCKS 


CHAtlNEL 
CH·U 


CONTROLS 
FOR MODEM, 
DMA,OR 
OTHER 


Z8Q31 Z8000™ Z-ASec 
Asynchronous Serial 
Communications Controller 


Product 
Specification 


September 1983 


II Asynchronous communications with five to 
eight bits per character and one, one and 
one-half, or two stop bits per character; pro- 
grammable clock factor; break·detection 
and generation; parity, overrun, and fram- 
ing error detection. 


troIs in both channels. In applications where. 
these controls are not needed, the modem con- 
trols can be used for general-purpose I/O. 


The Z-BUS daisy-chain interrupt hierarchy 
is also supported-as is standard for Zilog 
peripheral components. 
The Z8031 Z-ASCC is packaged in a 40-pin 
ceramic DIP and uses a single + 5 V power 
supply. 


AD, 
ADo 


AD3 
AD2 


ADs 
AD4 


AD7 
AD6 


iNr 
os 


lEO 
As 


lEI 
RIW 


INTACK 
CSo 


+5V 
CS, 


W/REQA 
GND 


RIA 
W/REQB 


RTxCA 
RiB 


RxDA 
RTxCB 


TRxCA 
RxDB 


TxDA 
TRxCB 


DTR/REQA 
TxDB 


RTSA 
DTR/REQB 


CTSA 
RTSB 


DCDA 
CTSB 


PCLK 
DCDB 


Figure 2. Pin Assignments 
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Pin 
Description 


290 


The following section describes the pin 
functions of the Z-ASCC.Figures 1 and 2 
detail the respective pin functions and pin 
assignments. 
ADo-AD7' Address/Data Bus (bidirectional, 
active High, 3-state). These multiplexed lines 
carry register addresses to the Z-ASCC as well 
as data or control information to and from 
the Z-ASCC. 
AS. Address Strobe (input, active Low). 
Addresses on ADo-AD7 are latched by the ris- 
ing edge of this signal. 
CSo. Chip Select 0 (input, active Low). This 
signal is latched concurrently with the 
addresses on ADo-AD7 and must be active for 
the intended bus transaction to occur. 


CSI. Chip Select 1 (input, active High). This 
second select signal must also be active before 
the intended bus transaction can occur. CSI 
must remain active throughout the transaction. 
CTSA, CTSB. Clear to Send (inputs, active 
Low). If these pins are programmed as Auto 
Enables, a Low on the inputs enables their 
respective transmitters. If not programmed as 
Auto Enables, they may be used as general- 
purpose inputs. Both inputs are Schmitt-trigger 
buffered to accommodate slow rise-time inputs. 
The Z-ASCC detects pulses on these inputs 
and can interrupt the CPU on both logic level 
transitions. 
DCDA, DCDB. Data Carrier Detect (inputs, 
active Low). These pins function as receiver 
enables if they are programmed for Auto 
Enables; otherwise they may be used as 
general-purpose input pins. Both pins are 
Schmitt-trigger, buffered to accommodate slow 
rise-time signals. The Z-ASCC detects pulses 
on these pins and can interrupt the CPU on 
both logic level transitions. 


DS. Data Strobe (input, active Low). This 
signal provides timing for the transfer of data 
into and out of the Z-ASCC. If AS and DS 
coincide, this is interpreted as a reset. 
DTR/REQA, DTR/REQB. Data. Terminal 
Ready/Request (outputs, active Low). These 
outputs follow the state programmed into the 
DTR bit. They can also be used as general- 
purpose outputs or as Request lines for a DMA 
controller. 
lEI. Interrupt Enable In (input, active High). 
IEI is used with lEO to form an interrupt daisy 
chain when there is more than one interrupt- 
driven device. A High IEI indicates that no 
other higher priority device has an interrupt 
under service or is requesting an interrupt. 
lEO. Interrupt Enable Out (output, active 
High). IEO is High only if IEI is High and the 
CPU is not servicing a Z-ASCC interrupt or 
the Z-ASCC is not requesting an interrupt 
(Interrupt Acknowledge cycle only). IEO is 


connected to the next lower priority device's 
IEI input and thus inhibits interrupts from 
lower priority devices. 
INT. Interrupt Request (output, open-drain, 
active Low). This signal is activated when the 
Z-ASCC requests an interrupt. ' 


INTACK. Interrupt Acknowledge (input, active 
Low). This signal indicates an active Interrupt 
Acknowledge cycle. During this cycle, the 
Z-ASCC interrupt daisy chain settles. When 
DS becomes active, the Z-ASCC places an 
interrupt vector on the data bus (if IEI is 


, High). INTACK is latched by the rising edge 
of AS. 


PCLK. Clock (input). This is the master 
ZcASCC clock used to synchronize internal 
signals. PCLK is not required to have any 
phase relationship with the master system 
clock, !=llthough the frequency of this clock 
must be at least 90% of the CPU clock fre- 
quencyfor a Z8000. PCLK is a TTL level 
signal. 
RxDA, RxDB. Receive Data (inputs, active 
High). These input signals receive serial data 
at standard TTL levels. 


RIA, RIB. Ring Indicator (inputs, active Low). 
These pins can act either as inputs or as part 
of the crystal oscillator circuit. 
In normal operation (crystal oscillator option 
not selected), these pins are inputs similar to 
CTS and DCD. In this mode, transitions on 
these lines affect the state of the Ring Indicator 
status bits in Read Register 0 (Figure 8) but 
have no other function. 


RTxCA, RTxCB. Receive/Transmit Clocks 
-(inputs, active Low). These pins can be pro- 
grammed in several different modes of opera- 
tion. In each channel, RTxC may supply the 
receive clock, the transmit clock, the clock for 
the baud rate generator, or the clock of the 
Digital Phase-Locked Loop. These pins can 
also be programmed for use with the respec- 
tive HI pins as a crystal oscillator. The receive 
clock jila y be 1, 16, 32, or 64 times the data 
rate in Asynchronous modes. 
RTSA, RTSB. Request To Send (outputs, 
active Low). When the Request To Send (RTS) 
bit in Write Register 5 (Figure 9) is set, the 
RTS Signal goes Low~ When the RTS bit is 
reset and Auto Enable is on, the signal goes 
High after the transmitter is empty. With Auto 
Enable off, the RTS pin strictly follows the state 
of the RTS b~t. Both pins can be used as 
general-purpose outputs. 


R/W. Read/Write (input). This signal specifies 
whether the operation to be performed is a 
read or a write. 


TxDA, TxDB. Transmit Data (outputs, active 
High). These output signals transmit serial data 
at standard TTL levels. 


Pin 
Description 
(Continued) 


TRxCA~ TRxCB. Transmit/Receive Clocks 
(inputs or outputs, active Low). These pins can 
be programmed in several different modes of 
operation. TRxC may supply the receive clock 
or the transmit clock in the input mode or sup- 
ply the output of the Digital Phase-Locked 
Loop, the crystal oscillator, the baud rate 
. generator, or the transmit clock in the output 
mode. 


W/REQA. W/REQB. Wait/Request (outputs, 
open-drain when programmed for a Wait func- 
tion, driven High or Low when programmed 
for a Request function). These dual-purpose 
outputs may be programmed as Request lines 
for a DMA controller or as Wait lines to 
synchronize the CPU to the Z-ASCC data rate .. 
The reset state is Wait. 


Functional 
The functional capabilities of the Z-ASCC 
handle data at a rate of 1116, 1132, or 1164 of 
the clock rate supplied to the receive and 
transmit clock inputs. 
Description 
can be described from two different points 


2042-108 


of view: as a data communications device, 
it transmits and receives data in a wide 
variety of data communications protocols; 
as a Z8000 peripheral, it interacts with the 
CPU and other peripheral circuits and is part 
of the system interrupt structure. 
Data Communications Capabilities. The 
Z-ASCC provides two independent full-duplex 
channels programmable for use in any com- 
mon Asynchronous data communication pro- 
tocol. Figure 3 and the following description 
briefly detail this protocol. 


Asynchronous Modes. Transmission and 
reception can be accomplished independently 
on each channel with five to eight bits per 
character, plus optional even or odd parity. 
The transmitters can supply one, one-and-a- 
half, or two stop bits per character and can 
provide a break output at any time. The 
receiver break-detection logic interrupts the 
CPU both at the start and at the end of a 
received break. Reception is protected from 
spikes by a transient spike-rejection 
mechanism that checks the signal one-half a 
bit time after a Low level is detected on the 
receive data input (RxDA or RxDBin 
Figure 1). If the Low does not persist (as in the 
case of a transient), the character assembly 
process does not start. 
Framing errors, and overrun errors are 
detected and buffered together with the partial 
character on which they occur. Vectored iIiter- 
rupts allow fast servicing of error conditions 
using dedicated routines. Furthermore, a 
built-in checking process avoids the interpreta- 
tion of a framing error as a new start bit: a 
framing error results in the addition of one-half 
a bit time to the point at which the search for 
the next start bit begins. 
The Z-ASCC does not require symmetric 
transmit and receive clock signals-a feature 
allowing use of the wide variety of clock 
sources. The transmitter and receiver can 


PARITY 
STrT 
llOP 


Baud Rate Generator. Each channel in the 
Z-ASCC contains a programmable baud rate 
generator. Each generator consists of two 8-bit 
time constant registers that form a 16-bit time 
constant, a 16-bit down counter, and a flip-flop 
on the output producing a square wave. On 
startup, the flip-flop on the output is set in a 
High state, the value in the time constant 
register is loaded into the counter, and the 
counter starts counting down. The output of 
the baud rate generator toggles upon reaching 
0, the value in the time constant register is 
loaded into the counter, and the process is 
repeated. The time constant may be changed 
at any time, but the new value does not take 
effect until the next load of the counter. 
The output of the baud rate generator may 
be used as either the transmit clock, the 
receive clock, or both. It can also drive the 
Digital Phase-Locked Loop (see next section). 
If the receive clock or transmit clock is not 
programmed to come from the TRxC pin, the 
output of the baud rate generator may b~ 
echoed out via the TRxC pin. 
- 


The following formula relates the time con- 


stant to the baud rate (the baud rate is in 
bits/second and the BR clock period is in 
seconds): 


. 
PCLK 
time constant = 2 (clock factor) (baud) - 
2 


Digital Phase-Locked Loop. The Z-ASCC 
contains a Digital Phase-Locked Loop (DPLL) 
to recover clock information from a data 
stream with NRZI or FM encoding. The DPLL is 
driven by a clock that is nominally 32 (NRZI) 
or 16 (FM) times the data rate. The DPLL uses 
this clock, along with the data stream, to con- 
struct a clock for the data. This clock may then 
be used as the Z-ASCC receive clock, the 
transmit clock, or both. 


~MA-R-KI-NG-L-IN--E---"II DATA III IIr--DA-T-A"'I"'I~I~11 DATA III I MARKING LINE 


ASYNCHRONOUS 


Figure 3. Z-ASCC Protocol 
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Functional 
Description· 
( Continued) 
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For NRZI encoding, the DPLL counts the 32x 
clock to create nominal bit times. As the 32x 
clock is counted, the DPLL is searching the 
incoming data stream for edges (either 1 to 0 
or 0 to 1). Whenever an edge is detected, the 
DPLL makes a count adjustment (during the 
next counting cycle), producing a terminal 
count closer to the center of the bit cell. 
For FM encoding, the DPLL still counts from 
o to 31, but with a cycle corresponding to two 
bit times. When the DPLL is .locked, the clock 
edges in the data stream should occur between 
counts 15 and 16 and between counts 31 and 
O. The DPLL looks for edges only during a 
time centered on the 15 to 16 counting 
transition. 
The 32x clock for the DPLL can be pro- 
grammed to come from either the RTxC input 
or the output of the baud rate generator. The 
DPLL output may be programmed to be 
echoed out of the Z-ASCC via the TRxC pin (if 
this pin is not being used as an input). 


Data Encoding The Z-ASCC may be pro- 
grammed to encode and decode the serial data 
in four different ways (Figure 4). In NRZ 
encoding, a 1 is represented by a High· level 
and a 0 is represented by a Low level. In NRZI 
encoding, a 1 is represented by no change in 
level and a 0 is represented by a change in 
level. In FMI (more properly, bi-phase mark) 
a transition occurs at the beginning of every 
bit cell. A 1 is represented by an additional 
transition at the center of the bit cell and a 0 is 
represented by no additional transition at the 
center of the bit cell. In FMO (bi-phase space), 
a transition occurs at the beginning of every 
bit cell. A 0 is represented by an additional 
transition at the center of the bit cell, and a 1 
is represented by no additional transition at 
the center of the bit cell. In addition to these 
four methods, the Z-ASCC can be used to 
decode Manchester (bi-phase level) data by 
using the DPLL in the FM mode and program- 
ming the receiver for NRZ data. Manchester 
encoding always produces a transition at the 
center of the bit cell. If the transition is 0 to I, 


DATA 


NRZ 
\ 


NRZI 
\ 


FM1 


FMIf 


MANCHESTER' 


the bit is a O. If the transition is 1 to 0 the 
bit is a 1. 
Auto Echo and Local Loopback~ The Z-ASCC 
is capable of automatically echoing everything 
it receives. In Auto Echo mode, RxD is con- 
nected to TxD internally. Auto Echo mode can 
be used with NRZI or FM encoding with no 
additional delay, because the data stream is 
not decoded before retransmission. In Auto 
Echo mode, the CTS inpuUs ignored as a 
transmitter enable (although transitions on this 
input can still cause interrupts if programmed 
to do so). In this mode, the transmitter is 
actually bypassed and the programmer is 
responsible for disabling transmitter interrupts 
and WAIT/REQUEST on transmit. 
The Z-ASCC is also capable of Local Loop- 
back. In this mode TxD is connected to RxD 
internally, just as in Auto Echo mode. 
However, in Local Loopback mode, the inter- 
nal transmit data is tied to the internal receive 
data and RxD is ignored (except to be echoed 
out via TxD). The CTS and DCD inputs are 
also ignored as transmit and receive enables. 
However; transitions on thes!3 inputs can still 
cause interrupts. Local Loopback works with 
NRZ, NRZI or FM coding of the data stream. 


I/O Interface Capabilities. The Z-ASCC 
offers the choice of Polling, Interrupt (vectored 
or nonvectored), and Block Transfer modes to 
transfer data, status, and control information to 
and from the CPU. The Block Transfer mode 
can be implemented under CPU or DMA 
control. 


Polling. All interrupts are disabled. Three 
status registers in the Z-ASCC are automat- 
ically updated when~ver any function is per- 
formed. The idea behind polling is for the 
CPU to periodically read a status register until 
the register contents indicate the need for data 
to be transferred. Only one register needs to 
be read; depending on its contents, the CPU 
either writes data, reads data, or continues. 
Two bits in the register indicate the need for 
data transfer. An alternative is a poll of the 


I 
\ 


I 
\ 


Figure 4. Data Encoding Methods 
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Interrupt Pending register to determine the 
source of an interrupt. The status for both 
channels resides in one register. 
Interrupts. The Z-ASCC interrupt scheme 
conforms to the Z-.BUS specification. When a 
Z-ASCC responds to an Interrupt Acknowledge 
signal (INTACK) from the CPU, an interrupt 
vector may be placed on the A/D bus. This 
vector is written in WR2 and may be read in 
RR2A or RR2B (Figures 8 and 9). 
To speed interrupt response time, the 


Z-ASCC can modify three bits in this vector to 
indicate status. If the vector is read in Channel 
A, status is never included; if it is read in 
Channel B, status is always included. 
Each of the six sources of interrupts in the 


Z-ASCC (Transmit, Receive, and Exter- 
nal/Status interrupts in both channels) has 
three bits associated with the interrupt source: 
Interrupt Pending (IP), Interrupt Under Ser- 
vice (IUS), and Interrupt Enable (IE). Opera- 
tion of the IE bit is straightforward. If the IE bit 
is set for a given interrupt source, then that 
source can request interrupts. The exception is 
when the MIE (Master Interrupt Enable) bit in 
WR9 is reset and no interrupts may be 
requested. The IE bits are write only. 
The other two bits are related to the Z-BUS 


interrupt priority chain (Figure 5). The 
Z-ASCC may request an interrupt only when 
no higher priority device is requesting one, 
e.g., when IEI is High. If the device in ques- 
tion requests an interrupt, it pulls down INT. 
The CPU then responds with INTACK, and the 
interrupting device places the vector on the 
AID bus. 
In the Z-ASCC, the IP bit signals a need for 
interrupt servicing. When an IP bit is 1 and 
the IEI input is High, the INT output is pulled 
Low, requesting an interrupt. In the Z-ASCC, 
if the IE bit is not set by enabling interrupts, 
then the IP for that source can never be set. 
The IP is set two or three AS cycles after the 
interrupt condition occurs. Two or three AS 
rising edges are required from the time an 
interrupt condition occurs until INT is acti- 
vated. The IP bits are readable in RR3A. 
The IUS bits signal that an interrupt request 
is being serviced. If an IUS is set, all interrupt 
sources of lower priority in the Z-ASCC and 


Z·BUS 
PERIPHERAL 


external to the Z-ASCC are prevented from 
requesting interrupts. The internal interrupt 
sources are inhibited by the state of the inter- 
nal daisy chain, while lower priority devices 
are inhibited by the IEO output of theZ-ASCC 
being pulled Low and propagated to subse- 
quent peripherals. An IUS bit is set during an 
Interrupt Acknowledge cycle if there are no 
higher priority devices requesting interrupts. 
There are three types of interrupts: 
Transmit, Receive, and External/Status. Each 
interrupt type is enabled under program con- 
trol with Channel A having higher priority 
than Channel B, and with Receiver, Transmit, 
and External/Status interrupts prioritized in 
that order within each channel. When the 
Transmit interrupt is enabled, the CPU is 
interrupted when the transmit buffer becomes 
empty. (This implies that the transmitter must 
have had a data character written into it so 
that it can become empty.) When enabled; the 
receiver can interrupt the CPU in one of 
three ways: 


IJ Interrupt on First Receive Character or 


Special Receive Condition. 


11 Interrupt on All Receive Characters or 


Special Receive Condition. 


e Interrupt on Special Receive Condition 


Only. 


Interrupt on First Character or Special Con- 


dition and Interrupt on Special Condition Only 
are typically used with the Block Transfer 
mode. A Special Receive Condition is receiver 
overrun, and, optionally, a parity error. The 
Special Receive Condition interrupt is different 
from an ordinary receive character available 
interrupt only in the status placed in the vector 
during the Interrupt Acknowledge cycle. In 
Interrupt on First Receive Character, an inter- 
rupt can occur from Special Receive Condi- 
tions any time after the first receive character 
interrupt. 
The main function of the External/Status 
interrupt is to monitor the signal transitions of 
the CTS, DCD, and RI pins; however, an 
External/Status interrupt is also caused by a 
Transmit Underrun condition, or a zero count 
in the baud rate generator, or by the detection 
of a Break. 


Z·BUS 
PERIPHERAL 
Z·BUS 
PERIPHERAL 


lEI ADo-AD7 INT INTACK lEO 
lEI ADo-AD7 iNT INTACK lEO 
lEI ADo-AD7 iNf INTACK 
+5V 


+5V 


ADo-AD7V-______________________________ ~ 
______________ ~ 


INT.-------------~;_--------------~~r_--------------~~~ 


INTACK~--------------~~--------------~~----------------~ 


Figure 5. Z-BUS Interrupt Schedule 
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CPU/DMA Block Transfer. TheZ-ASCC pro- 
vides a Block Transfer mode to accommodate 
CPU block transfer functions and DMA con- 
trollers. The Block Trarisfer mode uses the 
WAIT/REQUEST output in conjunction with the 
Wait/Request bits in WRl. The WAIT/ 
REQUEST output can be defined under soft- 
ware control as a WAIT line in the CPU Block 
Transfer mode or as a REQUEST line in the 


The Z-ASCC internal structure includes 
two full-duplex channels, two baud rate 
generators, intern9-1 control and interrupt 
logic, and a bus interface to the Zilog Z-BUS. 
Associated with each channel are a number of 
read and write registers for mode control and 
status information, as well as logic necessary to 
interface to modems or other external devices 
(Figure 6). 
The logic for both channels provides 
formats, synchronization, and validation for 


ADDRESS/~ 
DATA~ 


CONTROL 


CPU 
BUS I/O 


INTERRUPT 
CONTROL 
LINES 
, . . 
I I I 


+SVGND PCLK 


INTERNAL 
CONTROL 
LOGIC 


INTERRUPT 
CONTROL 
LOGIC 


INTERNAL BUS 


DMA Block Transfer mode. 
To a DMA controller, the Z-ASCC REQUEST 


output indicates that the Z-ASCC is ready to 
transfer data to or from memory. To the CPU, 
the WAIT line indicates that the Z-ASCC is not 
ready to transfer data, thereby requesting that 
the CPU extend the I/O cycle. The DTR/ 
REQUEST line allows full-duplex operation 
under DMA control. 


data transferred to and from the channel inter- 
face. The modem control inputs are monitored 
by the control logic under program control. 
All of the modem control signals are general- 
purpose in nature and can optionally be used 
for functions other than modem control. 
The register set for each channel includes 
ten control (write) registers, and four status 
(read) registers. In addition, each baud rate 
generator has two (read/write) registers for 
holding the time constant that determines the 


BAUD RATE 
GENERATOR 
A 


CHANNEL A 
REGISTERS 


WAIT/REQUEST 


_ 
} 
MODEM, DMA, OR 
OTHER CONTROLS 


-} 
MODEM, DMA, OR 
OTHER CONTROLS 
B 


ISERIALDATA 


CHANNEL 5 
}.':HANNEL CLOCKS 


RI 


WAIT/REQUEST 


Figure 6. Block Diagram of Z-ASCC Architecture 
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RECEIVE 
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Figure 1. Data Path 
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Architecture 
(Continued) 
baud rate. Finally, associated with' the inter- 
rupt logic is a write register for the interrupt 
vector accessible through either channel, a 
write-only Master Interrupt Control register 
and three read registers: one containing the 
vector with status infomation (Channel B only), 
one containing the vector without status 
(Channel A only), and one containing the 
Interrupt Pending bits (Channel A only). 
The registers for each channel are 
designated as follows: 


WRO-WR 15 - 
Write Registers 0-5, 8-15. 


RRO-RR3, RRIO, RRI2, RRI3, RR15 - 
Read 
Registers 0 through 3, 10, 12, 13, 15. 


Table 1 lists the functions assigned to each 
read or write register. The Z-ASCC contains 
only one WR2 and WR9, but they can be 
accessed by either channel. All other registers 
are paired (one for each channel). 


Data Path. The transmit and receive data path 
illustrated in Figure 7 is identical for both 
channels. The receiver has three 8-bit buffer 
registers in an FIFO arrangement, in addition 
to the 8-bit receive shift register. This scheme 
creates additional time for the CPU to service 
an interrupt at the beginning of a block of 
high speed data. Incoming data is routed 
through one of several paths depending on the 
selected mode (the character length deter- 
mines the data path). 
The transmitter has an 8-bit Transmit Data 
buffer register loaded from the internal data 
bus and an 11-bit Transmit Shift register that is 
loaded from the Transmit Data register. 


Programming. 
The Z-ASCC contains 11 write registers in 
each channel that are programmed by the 
system separately to configure the functional 
personality of the channels. All of the registers 
in the Z-ASCC are directly addressable. How 
the Z-ASCC decodes the address placed on 
the address/data bus at the beginning of a 
Read or Write cycle is controlled by a com- 
mand issued in WROB. In the shift right mode, 
the channel select NB is taken from ADo and 
the state of AD5 is ignored. In the shift left 
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RRO 


RRI 


RR2 


RR3 


RR8 


RRIO 


RR12 


RR13 


RR15 


WRO 


WRI 


WR2 
WR3 
WR4 


WR5 


WR8 


WR9 


WRlO 


WRll 
WRl2 
WR13 
WR14 
WRl5 


Read Register Functions 


TransmiVReceive buffer status and External status 


Special Receive Condition status 


Modified interrupt vector (Channel B only) 
Unmodified interrupt vector (Channel A only) 


Interrupt Pending bits (Channel A only) 


Receive buffer, 


Miscellaneous status 


Lower byte of baud rate generator time constant 


Upper byte of baud rate generator time constant 


External/Status interrupt information 


Write Register Functions 


CRC initialize, initialization commands for the 
various modes, shift righVshift left command 


TransmiVReceive interrupt and data transfer mode 
definition 


Interrupt vector (accessed through either channel) 


Receive parameters and control 


TransmiVReceive miscellaneous parameters and 
modes 


Transmit parameters and controls 


Transmit buffer 


Master interrupt control and reset (accessed 
through either channel) 


Miscellaneous transmitter/receiver control bits 


Clock mode control 


Lower byte of baud rate generator time constant 


Upper byte of baud rate generator time constant 


Miscellaneous control bits 


External/Status interrupt control 


Table 1. Read and Write Register Functions 


mode, NB is taken from AD5 and the state of 
ADo is ignored. AD7 and AD6 are always 
ignored as address bits and the register 
address itself occupies AD4 - ADl. 
The system program first issues a series of 
commands to initialize the basic mode of 
-, 


operation. For example, the character length, 
clock rate, 'number of stop bits, even or odd 
parity might be set first. Then the Interrupt 
mode would be set, and finally, receiver or 
transmitter enable. 


Programming 
( Continued) 
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Read Registers. The Z-ASCC contains eight 
read registers (actually nine, counting the 
receive buffer [RR8]) in each channel. Four of 
these may be read to obtain status information 
(RRO, RRl, RRlO, and RRlS). Two registers 
(RR12 and RR13) may be read to learn the 
baud rate generator time constant. RR2 con- 
tains either the unmodified interrupt vector 
(Channel A) or the vector modified by status 
information (Channel B). RR3 contains the 


Read Register 0 
~ 


I llli ~i~~:::::"~'" 
~ 
RING INDICATOR 


CTS 
1. 
'-------- BREAK 


Read Register 1 


I~I~I~I~I~I~I~I~I . 


Read Register 2 


'-------- V7 


'MODIFIED IN B CHANNEL 


Read Register 3 


INTERRUPT VECTOR' 


~~illt1, 


~ 
CHANNELBEXT/STATIP' 
L 
CHANNEL B Tx IP' 


CHANNEL B Rx IP' 


CHANNEL A EXT/STAT IP' 


. 
CHANNEL A Tx IP' 


CHANNEL A Rx IP' 
o 


'ALWAYS 0 IN B CHANNEL 


Interrupt Pending OP) bits (Channel A). 
Figure 8 shows the formats for each read 
register. 
The status bits of RRO and RRI are carefully 
grouped to simplify status monitoring; e.g., 
when the interrupt vector indicates a Special 
Receive Condition interrupt, all the appro- 
priate error bits can be read from a single 
register (RRl). 


Read Register 10 


'-------- ONE CLOCK MISSING 


Read Rogister 12 


~1~ 
'-------- TC7' 


Read Register 13 


'--______ TC15 


Read Register 15 


LOWER BYTE OF 
TIME CONSTANT 


UPPER BYTE OF' 
TIME CONSTANT 


II illt1 ~~::'"~" 
2=" 
1 


'-------- BREAK IE 


Figure 8. Read Register Bit Functions 
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Programming 
(Continued) 
Write Registers. The Z-ASCC contains 11 
write registers (12 counting WR8, the transmit 
buffer) in each channel. These write registers 
are programmed separately to configure the 
functional "personality" of the chami.els. In 
addition, there are two registers (WR2 and 


Write Register 0 
1 


0 
0 
NULL CODE 


o 1 
NULL CODE 


1 
0 
SELECT SHIFT LEFT MODE' 


1 
1 
:ELECTSHIFT RIGHT MODE' 


0 
0 
0 
NULL CODE 


0 
0 
1 
NULL CODE 


0 
1 
0 
RESET EXT/STATUS INTERRUPTS 


0 
1 
1 
NULL CODE 


1 
0 
0 
ENABLE INT ON NEXT Rx CHARACTER 


1 
0 
1 
RESET Tx INT PENDING 


1 
1 
0 
ERROR RESET 


1 
1 
1 
RESET HIGHEST IUS 


Write Register 1 


I~I~I~I~I~I~I~I~I 
II L ,no", .. ", 
L 
Tx INT ENABLE 


PARITY IS SPECIAL CONDITION 


o Rx INT DISABLE 


1 
Rx INT ON FIRST CHARACTER OR SPECIAL CONDITION 


1 
OINT ON ALL Rx CHARACTERS OR SPECIAL CONDITION 


1 
1 
Rx INT ON SPECIAL CONDITION ONLY 


1...-_____ WAITIDMA REQUEST ON RECEIVEITRANSMIT 
'-------- WAITIDMA REQUEST FUNCTION 
'--------- WAIT/DMA REQUEST ENABLE 


Write Register 2 


INTERRUPT VECTOR 


'---------- V7 


WR9) shared by the two channels that may be 
accessed through either of them. WR2 contains 
the interrupt vector for both channels, while 
WR9 contains the interrupt control bits. Figure 
9 shows the format of each write register. 


Write Register 3 


i~I~I~I~I~I~I~I~1 


~t:::~~,,~ 


o 
0 
Rx 5 BITS/CHARACTER 


o 
1 
Rx 7 BITS/CHARACTER 


1 
0 
Rx 6 BITS/CHARACTER 


1 
1 
Rx 8 BITS/CHARACTER 


Write Register 4 


~ 


I L PARITY ENABLE 
L 
PARITY EVEN/ODD 


o 0 
DO NOT PROGRAM 


o 
1 
1 STOP BITICHARACTER 


1 
0 
1 'Iz STOP BITS/CHARACTER 


1 
1 
2 STOP BITS/CHARACTER 


o 
0 
'X 1 CLOCK MODE 


o 1 
X16 CLOCK MODE 


1 
0 
X32 CLOCK MODE 


1 
1 
X64 CLOCK MODE 


Write Register 5 


o 
0 
Tx 5 BITS (OR LESS)/CHARACTER 


o 
1 
Tx 7 BITS/CHARACTER 


1 
0 
Tx 6 BITS/CHARACTER 


1 
1 
Tx 8 BITS/CHARACTER 
'---------- DTR 


Figure 9, Write Register Bit Functions 


2245-006 


Programming Write Register 9 
(Continued) 


~~ 


~~~ 
L 
DLC 


MIE 


:TATUS HIGHISTATUS LOW 


o 
NO RESET 


1 
CHANNEL RESET B 


1 
0 
CHANNEL RESET A 


1 
'1 
FORCE HARDWARE RESET 


Writer Register 10 


o 
0 
NRZ 


o 
1 
NRZI 


1 
0 
FM1 (TRANSITION = 1) 


1 
1 
FMO (TRANSITION = 0) 


Write Register 11 


[1 


0 
0 
TRxC OUT = XTAL OUTPUT 


o 
1 
TRxC OUT = TRANSMIT CLOCK 


1 
O. TRxC OUT = BR GENERATOR OUTPUT 


1 
1 
TRxC OUT = DPLL OUTPUT 


TRxC oli 
- 


o 
0 
TRANSMIT CLOCK = RTxC PIN 


o 
1 
TRANSMIT CLOCK = TRxC PIN 


1 
0 
TRANSMIT CLOCK = BR GENERATOR OUTPUT 


1 
1 
TRANSMIT CLOCK = DPLL OUTPUT 


o 
0 
RECEIVE CLOCK = RTxC PIN 


o 1 
RECEIVE CLOCK = TRxC PIN 


1 
0 
RECEIVE CLOCK = BR GENERATOR OUTPUT 


1 
1 
RECEIVE CLOCK = DPLL OUTPUT 
"--------- ffTxC XTAUNO XTAL 


Write Register 12 


I~I~I~I~I~I~I~I~I 
~~ 


'---------- TC7 


Write Register 13 


'---------- TC15 


Write Register 14 


LOWER BYTE OF 
TIME CONSTANT 


UPPER BYTE OF 
TIME CONSTANT 


~~ 


L BR GENERATOR ENABLE 
L 
BR GENERATOR SOURCE 


D'fRIREQUEST FUNCTION 


AUTO ECHO 


LOCAL LOOPBACK 


0 
0 
0 
NULL COMMAND 


0 
0 
1 
ENTER SEARCH MODE 


0 
1 
RESET MISSING CLOCK 


0 
1 
DISABLE DPLL 


1 
0 
0 
SET SOURCE = BR GENERATOR 


1 
0 
1 
SET SOURCE = RTxC 


1 
1 
0 
SET FM MODE 


1 
1 
1 
SET NRZI MODE 


Write Register 15 


I~I~I~I~I~I~I~I~I 


~~~:ro"m" 


'---------- BREAK IE 


Figure 9. Write Register Bit Functions (Continued) 
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Timing 
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The Z-ASCC generates internal control 
signals from AS and DS that are related to 
PCLK. Since PCLK has no phase relationship 
with AS and DS, the circuitry generating these 
internal control signals must provide time for 
metastable conditio~s to disappear. This gives 
rise to a recovery time related to PCLK. The 
recovery time applies only between bus trans- 
actions involving the Z-ASCC. The recovery 
time required for proper operation is specified 
from the rising edge of DS in the first transac- 
tion involving the Z-ASCC to the falling edge 


CSo 
\ 
I 


/ 
\ 


ADo-AD7 
X 


ADDRESS ) 


- R/Vi 
/ 


/ 


of DSin the second transaction involving the 
Z-ASCC. This time must be at'least 6 PCLK 
cycles plus 200 ns. 


Read Cycle Timing. Figure 10 illustrates 
Read cycle timing. The address on ADo-AD 7 
and the state of CSo and INTACK are latched 
by the rising edge of AS. R!W must be High to 
indicate a Read cycle. CSI must also be High 
for the Read cycle to occur. The data bus 
drivers in the Z-ASCC are then enabled while 
DS is Low~ 


( '--____ .."x 
DATA VALID 
}-- 


c 
\\-. ____ ----J;- 


Figure 10. Read Cycle T~ming 


Write Cycle Timing. Figure II illustrates 
Write cycle timing. The address on ADo-AD7 
and the state of CSo and INTACK are latched 
by the rising edge of AS. R/W must be Low to 


CSo 
\ 
I 


/ 
\ 


indicate a Write cycle. CSI must be High for 
the Write cycle to occur. DS Low strobes the 
data into the Z-ASCC. 


ADo-AD7 
X 
ADDRESS x:x 


DATA 
~ 
____ 
X= 


R/Vi 
\ 
/ 


r= 
'C 


\~----------~;- 


Figure 11. Write Cycle Timing 


Interrupt Acknowledge Cycle Timing. 
Figure 12 illustrates Interrupt Acknowledge 
cycle timing. The address on ADo-AD7 and 
the state of CSo and INTACK are latched by 


the rising edge of AS. However, if INTACK is 
Low, the address and CSo are ignored. The 
state of the R/W and CSI are also ignored for 
the duration of the Interrupt Acknowledge 
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Timing 
(Continued) 
cycle. Between the rising edge of AS and the 
falling edge of DS, the internal and external 
IEl/IEO daisy chains settle. If there is an inter- 
rupt pending in the Z-ASCC and IEI is High 
when DS falls, the Acknowledge cycle was 


X 


(IGNORED) X 
CSo ___ 
J 


~ 
I 


ADO-AD7 
X 


(IGNORED) ) 


~ 
, 


':' :, 


/f 


I 


intended for the Z-ASCC. In this case, the 
Z-A,SCC may be programmed to respond to 
DS Low by placing its interrupt vector on 
ADo-AD7. It then sets the appropriate 
Interrupt-Under-Service latch internally. 


ex 
VECTOR }- 


Figure 12. Interrupt Acknowledge Cycle Timing 


Absolute 
Maximum 
Ratings 


Standard 
Test 
Conditions 


DC 
Charac- 
teristics 


Voltages on all inputs and outputs 
with respect to GND .......... -0.3 V to + 7.0 V 
Operating Ambient 
Temperature ................. As Specified in 
Ordering Information 
Storage Temperature ........ -65°C to + 150 °C 


The characteristics below apply for the 
following standard test conditions, unless 
otherwise noted. All voltages are referenced to 
GND. Positive current flows into the refer- 
enced pin. Standard conditions are as follows: 


Symbol 


+5V 


2.1K 


Figure 13. Standard Test Load 


Parameter 


Input High Voltage 
Input Low Voltage 
Output High Voltage 
Output Low Voltage 
Input Leakage 
Output Leakage 
Vee Supply Current 


Min 


2.0 
-0.3 
2.4 


Stresses greater than those listed under Absolute Maxi- 


mum Ratings may cause permanent damage to the device. 
This is a stress rating only; operation of the device at any 
condition above those indicated in the operational sections 
of these specifications is not implied. Exposure to absolute 
maximum rating conditions for extended periods may affect 
device reliability. 


[J +4.75 V ~ Vee ~ +5.25 V 


iJ GND = 0 V 


IJ TA as specified in Ordering Information 
All ac parameters assume a load capacitance 
of 50 pF max. 


FROM OUTPUT 
UNDER TEST 


+5V 


~ 


2.2K 


r 


50PF 


Figure 14. Open-Drain Test Load 


Max 
Unit 
Condition 


Vcc +0.3 
V 
0.8 
V 
V 
IOH = -250 pA 
0.4 
V 
IOL = +2.0 rnA 
± 10.0 
pA 
0.4 :S VIN :S + 2.4V 


±1O.0 
pA 
0.4 :S Your :S + 2.4V 
250 
rnA 


Vee = 5 V ± 5% unless otherwise specified, over speCified temperature range. 


Capacitance 
Symbol 
Parameter 


Input Capacitance 
Output Capacitance 
Bidirectional Capacitance 


f = I MHz, over specified temperature range. 
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Min 
Max 


10 
15 
20 


Unit 


pF 
pF 
pF 


Test Condition 


Unmeasured Pins 
Returned to Ground 
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I 
w 
.... 


Read and 
Write 
Timing 


Cio 


Riw 
READ ____ -++-_,.,1 


R/W 


WRITE -----1-+----++-+-------------1-4----------- 


ADo-ADr 


WRITE ___ 
, 1'o-+-+--"'l 


·ADo-ADr 


READ __ 
--' l-++--'I 


W/REQ 


WAIT 


W/REQ 


REQUEST _____ -+-_____ -+ ___ --' 


DTR/REQ 


REQUEST _____ -+-_____________________ _ 


14-~--__{28l_---_t------------------ 


4 MHz 
No. 
Symbol 
Parameter 
Min 
Max 


1 
TwAS 
AS Lov; Width 
70 


2 
TdDS(AS) 
DS I to AS I Delay 
50 


3 
TsCSO(AS) 
CSo to AS I Setup Time 
0 


4 
ThCSO(AS) 
CSo to AS I Hold Time 
60 
5-:-TsCS1(DS)-- CSI to DS I Setup Time---------- 100 
6 
ThCS1(DS) 
CS] to DS IJioid Time 
55 
7 
TsIA(AS) 
INTACK to AS I Setup Time 
0 


8 
ThIA(AS) 
INTACK to AS I Hold Time 
250 
100 
55 
9 
TsRWR(DS) 
R/W (Read) to DS I Setup Time 
10 - 
ThRW(DS)-- RIW to DS I Hold Time ---------- 
11 
TsRWW(DS) 
RIW (Write) to DS I Setup Time 
0 


12 
TdAS(DS) 
AS I to DS I Delay 
60 


13 
TwDSl 
DS Low Width 
390 


14 
TrC 
Valid Access Recovery Time 
6TcPC 
+200 


15 - 
TsA(AS) --- Address to AS I Setup Time --------- 30 


16 
ThA(AS) 
Address to AS I Hold Time 
50 


17 
TsDW(DS) 
Write Data to DS I Setup Time 
30 


18 
ThDW(DS) 
Write Data to DS I Hold Time 
30 


19 
TdDS(DA) 
DS I to Data Active Delay 
0 
20 -TdDSr(DR)-- DS I to Read Data Not Valid Delay------- 0 
21 
TdDSf(DR) 
DS I to Read Data Valid Delay 
250 


22 
TdAS(DR) 
AS I to Read Data Valid Delay 
520 


NOTES: 


the Z-ASCC. 


6 MHz 
Min 
Max 


50 
25 
0 
40 


Notes*t 


1 
1 


80 -------1- 
40 
1 


0 
250 
80 
40 
0 
40 
250 
6TcPC 
2 
+ 130 


10 -------1- 
30 
1 


20 
20 
0 
0 
180 
335 


1. Parameter does not apply to Interrupt Acknowledge 
transactions. 
"Timings are preliminary and subject to change. 
2. Parameter applies only between transactions involving 
t Units in nanoseconds (ns). 
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Interrupt 
Acknow ledge 
Timing 


Ai 


ADO-AD7----------------------+---------------~--_r 


Reset 
Timing 


Cycle 
Timing 


No. 
Symbol 


IIlI 


1110 


PCLK 


Parameter 


23 
TdDS(DRz) 
DSt to Read Data Float Delay 


Min 


/. 


4 MHz 
6MHz 
Max 
Min 
Max 
Notes*t 


70 
45 
3 
24 
TdA(DR) 
Address Required Valid to Read Data Valid Delay 
570 
420 
25 
TdDS(W) 
DS , to Wait Valid Delay 
240 
200 
4 
240 
200 
5TcPC 
5TcPC 


26 
TdDSf(REQ) 
DS , to W/REQ Not Valid Delay 
27-TdDSr(REQ)- DS i to DTRlREQ Not Valid Delay--------- 


+300 


28 
TdAS(INT) 
AS t to INT Valid Delay 
500 


29 
TdAS(DSA) 
AS t to DS , (Acknowledge) Delay 


30 
TwDSA 
DS (Acknowledge) Low Width 
390 
31 
TdDSA(DR) 
DS , (Acknowledge) to Read Data Valid Delay 
250 


+250 


500 


250 
180 


4 
5 


32 - 
TsIEI(DSA) -- IEI to DS , (Acknowledge) Setup Time ----- 120 
100 


33 
ThIEI(DSA) 
lEI to DS t (Acknowledge) Hold Time 
0 


34 
TdIEI(IEO) 
IEI to IEO Delay 
35 
TdAS(IEO) 
AS t to IEO Delay 
36 
TdDSA(INT) 
DS , (Acknowledge) to INT Inactive Delay 


0 


120 
250 
500 


100 
250 
500 


6 
4 
37 - 
TdDS(ASQ) -- DS t to AS , Delay for No Reset -------- 30 
15 
38 
TdASQ(DS) 
AS t to DS , Delay for No Reset 
30 
30 


39 
TwRES 
AS and DS Coincident Low for Reset 
250 
250 
7 


40 
TwPCl 
PCLK Low Width 
105 
2000 
70 
1000 


41 
TwPCh 
PCLK High Width 
105 
2000 
70 
1000 
42-TcPC 
PCLK Cycle Time ------------ 250 - 
4000 --165- 2000 


43 
TrPC 
PCLK Rise Time 
44 
TfPC 
PCLK Fall Time 


NOTES: 
3. Float delay is defined as the time required for a ± 0.5 V change 
in the output with a maximum dc load and minimum ac load. 
4. Open-drain output, measured with open-drain test load. 
5. Parameter is system dependent. For any Z-ASCC in the daisy 
chain, TdAS(DSA) must be greater than the sum of TdAS(IEO) 
for the highest priority device in the daisy chain, TsIEI(DSA) 
for the Z·ASCC, and TdIEIf(IEO) for each device separating 
them in tll') daisy chain. 


2016·011. 012, 013 


20 
15 


20 
10 


6. Parameter applies only to a Z·ASCC pulling INT Low at the 
beginning of the Interrupt Acknowledge transaction. 
7. Internal circuitry allows for the reset provided by the Z8 to be 
recognized as a reset by the Z-ASCC . 


• Timings are preliminary and subject to change. All timing refer- 


ences assume 2.0 V for a logic "1" and 0.8 V for a logic "0". 


t Units in nanoseconds (ns). 
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PeLf( 


WIREQ 


REQUEST 


WIREQ 


WAIT ______________________ ~------------------------------I 


RTaC,TRaC 


RECEIVE ----------------....;1["" 


RaD 


TRaC,RTaC 
TRANSMIT 


TaD_Cl-: _~ 


--------'-~-------_-_®_II~---~~~:~ 
TRaC 
~------------------------------------------------- 
OUTPUT __________________________ ~ ~ 
______________________________________________ ___ 
''------ ~~" 
1 
.i==3~ 


TRaC-----\~ ______ ~--------'--~r---- 


CTa, DCD, iii 
1ft. 
/ 
_ _ _ 
r~~ 


2245-007 


4 MHz 
6MHz 
No. 
Symbol 
Parameter 
Min 
Max 
Min 
Max 
Notes*t 


TdPC(REQ) 
PCLK 1 to W IREQ Valid 
250 
250 


2 
TdPC(W) 
PCLK 1 to Wait Inactive Delay 
350 
350 


3 
TsRXC(PC) 
RxC t to PCLK t Setup Time (PCLK -;- 4 case only) 
80 
TwPCl 
70 
TwPCI 
1,4 
4 
TsRXD(RXCr) 
RxD to RxC t Setup Time (Xl Mode) 
5- ThRXD(RXCr) - 
RxD to RxC t Hold Time (Xl Mode) 


6 
TsRXD(RXCf) 
RxD to RxC 1 Setup Time (Xl Mode) 


7 
ThRXD(RXCf) 
RxD to RxC 1 Hold Time(Xl Mode) 


8 
TsTXC(PC) 
TxC 1 to PCLK t Setup Time 


9 
TdTXCf(TXD) 
TxC 1 to TxD Delay (Xl Mode) 


10 - 
TdTXCr(TXD) - 
TxC t to TxD Delay (Xl Mode) 


11 
TdTXD(TRX) 
TxD to TRicC Delay (Send Clock Echo) 
12 
TwRTXh 
RTxC High Width 


13 
TwRTX1 
RTxC Low Width 


14 
. TcRTX 
RTxC Cycle Time 


0 
150 


0 
150 


0 


300 


300 


180 


180 


400 


0_ 


150 -------1- 


0 
150 


0 


1,5 
1,5 


2,4 


300 
2 
----- 300 --- 2,5- 


180 


180 


400 


6 
6 
6 
15 - 
TcRTXX --- Crystal Oscillator Period ---------- 250 -1000 -- 250 - 
1000 --- 3- 
16 
TwTRXh 
TRxC High Width 


17 
TwTRXl 
TRxC Low Width 


18 
TcTRX 
TRxC Cycle Time 


19 
TwEXT 
DCD or CTS or RI Pulse Width 


NOTES: 
I. RxC is RTxC or TRxC, whichever is supplying the receive 
clock. 
2. TxC is TRxC or RTxC, whichever is supplying the transmit 
clock. 
3. Both RTxC and ill have 30 pF capacitors to the ground 
connected to them. 
4. Parameter applies only if the data rate is one-fourth the PCLK 


rate. In all other cases, no phase relationship between RxC and 


180 


180 


400 


200 


180 


180 


400 


200 


PCLK or TxC and PCLK is required. 
5. Paramet~r applies only to FM encoding/decoding. 


6 
6 
6 


6. Parameter applies only for transmitter and receiver; DPLL and 
baud rate generator timing requirements are identical to chip 
PCLK requirements . 


• Timings are preliminary and subject to change. 
t Units in nanoseconds (ns). 
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N 
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W 
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n 
n 


System 
Timing 


No. 
Symbol 


TdRXC(REQ) 
2 
TdRXC(W) 
3 
TdRXC(INT) 


RTJlC,TRJlC 


RECEIVE 


W/REQ 
REQUEST 


W/REQ 


WAIT 


RTJlC, TRJlC 


TRANSMIT 


W/REQ 
REQUEST 


W/REQ 


WAIT 


DTRlREQ 
REQUEST 


CTS, DCD,RI 


INT 


. Parameter 


RxC t to W /REQ Valid Delay 


RxC t to Wait Inactive Delay 


RxC t INT Valid Delay 


4 - 
TdTXC(REQ)-TxC l to W/REQ Valid Delay 
5 
TdTXC(W) 
TxC l to Wait Inactive Delay 
6 
TdTXC(DRQ) 
TxC l to DTRlREQ Valid Delay 
7 
TdTXC(INT) 
TxC l to INT Valid Delay 


t 


8 
TdEXT(INT) 
DCD, ru or CTS Transition to INT Valid Delay 


NOTES: 
1. ~n-drain output, measured with open-drain test load. 
2. RxC Is RTxC or TRxC, whichever is supplying the receive 
clock. 
3. TxC is TRxC or RTxC, whichever is supplying the transmit 
clock. 
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CD 
~ 


4 MHz 
6 MHz 
Min 
Max 
Min 
Max 
Notes* 


8 
12 
8 
12 
2,4 


8 
12 
8 
12 
1,2,4 
8 
12 
8 
12 
1,2,4 
+2 
+3 
+2 
+3 
5 
5--8 
5--8--·-3,4- 
5 
8 
5 
8 
1,3,4 


4 
7 
4 
7 
3,4 
4 
6 
4 
6 
1,3,4 
+2 
+3 
+2 
+3 
5 
2 
3 
2 
3 
1,5 


4. Units equal to Tcpe. 
5. Units equal to AS. 
• Timings are preliminary and subject to change. 


2245-008 


Ordering 
Product 
Package/ 
Product 
Package/ 
Information 
Number 
Temp 
Speed 
Description 
Number 
Temp 
Speed 
Description 


Z8031 
CE 
4.0 MHz 
Z-ASCC (40-pin) 
Z8031A 
CE 
6.0 MHz 
Z-ASCC (40-pin) 


Z8031 
CM 
4.0 MHz 
Same as above 
Z8031A 
CM 
6.0 MHz 
Same as above 


Z8031 
CMB 
4.0 MHz 
Same as above 
Z8031A 
CMB 
6.0 MHz 
Same as above 


Z8031 
CS 
4.0 MHz 
Same as above 
Z8031A 
CS 
6.0 MHz 
Same as above 


Z8031 
DE 
4.0 MHz 
Same as above 
Z8031A 
DE 
6.0 MHz 
Same as above 


Z8031 
DS 
4.0 MHz 
Same as above 
Z8031A 
DS 
6.0 MHz 
Same as above 


Z8031 
PE 
4.0 MHz 
Same as above 
Z8031A 
PE 
6.0 MHz 
Same as above 


. Z8031 
PS 
4.0 MHz 
Same as above 
Z8031A 
PS 
6.0 MHz 
Same as above 


NOTES: C = Ceramic, D = Cerdip, P = Plastic; E = -40°C to +85°C, M = -55°C to 125°C, MB = -55°C to + 125°C with 
MIL-STD-883 with Class B processing, S = O°C to + 70°C. 


I 
w 
... 
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Zilog 


Features 


General 
Description 


2014-0035, 00,36 


Ell Two independent 8-bit, double-buffered, 
bidirectional I/O ports plus a 4-bit 
special-purpose I/O port. I/O ports 
feature programmable polarity, 
programmable direction (Bit mode), "pulse 
catchers," and programmable open- 
drain outputs. 


c Four handshake modes, including 3-Wire 
(like the IEEE-488). 


EJ REQUEST/WAIT signal for high-speed data 
transfer. 


The Z8036 Z-CIO Counter/Timer and 


Parallel I/O element is a general-purpose 
peripheral circuit, satisfying most 
counter/timer and parallel I/O needs 
encountered in system designs. This versatile 
device contains three I/O ports and three 
counter/timers. Many programmable options 
tailor its configuration to specific applications. 


1 


- 
AD7 
PA7_) 
_ 
AD6 
PA6 _ 


. 
_ADs 
PAs 
_ 


ADDRESS/DATA 
- 
AD, 
PA, - 
PORT A 
BUS 
_ 
AD3 
PA3 _ 
_ 
AD2 
PA2 
_ 
ADl 
PAl 


_ 
ADo 
PAo _ 


BUS TIMING { 
- 
AS 
PC3 - 
} 
AND RESET 
_ 
Os 
za036 PC2 _ 


{ 


_ 
RtW 
Z.CIO 
pC 
l 


_ 
PORT C 


CONTROL 
- 
CSo 
PCo - 


_CSl 
PB7_) 
iNT 
PB6 _ 


_ 
INTACK 
PBs _ 


INTERRUPT { 
lEI 
PB 
- 
4 
- 
PORTB 
lEO 
PB3 _ 


PB2 
- 
PB 
l 


_ 
PB 
o 
_ 


PCLK + 5 V GND 


Figuro 1. Pin Functions 


18036 Z8000™ z-elo 
Counler/Timer and 


~allai1Rei i/O iJ'niil 


Product 
Specification 


September 1983 


EI Flexible pattern-recognition logic, program- 
mable as a 16-vector interrupt controller. 


m Three independent 16-bit counter/timers 
with up to four external access lines per 
counter/timer (count input, output, gate, 
and trigger), and three output duty cycles 
(pulsed, one-shot, and square-wave), 
programmable as retriggerable or 
nonretriggerable. 


C Easy to use since all registers are read/write 
and directly addressable. 


The use of the device is simplified by making 
all internal registers (command, status, and 
data) readable and (except for status bits) 
writable. In addition, each register is given its 
own unique address so that it can be 
accessed directly-no special sequential 
operations are required. The Z-CIO is directly 
Z-Bus compatible. 


AD3 


AD2 


ADl 


ADo 
CsO 


PAo 


PBl 
PAl 


PA2 


PA3 


PA, 


PAs 


PA6 


PA7 


INTACK 
iNT 
+5V 


PC3 


PC2 


Figure 2. Pin Assignments 
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Pin 
ADo-AD7. Z-Bus Address/Data lines 
INT. Interrupt Request (output, open-drain, 
active Low). This signal is pulled Low when 
the Z-CIO requests an interrupt. 
Description 
(bidirectional/3-state). These multiplexed 
Address/Data lines are used for transfers 
between the CPU and Z-CIO. 
INTACK. Interrupt Acknowledge (input, active 
Low). This signal indicates to the Z-CIO that 
an Interrupt Acknowledge cycle is in progress. 
INTACK is sampled while AS is Low. 


AS*. Address Strobe (input, active Low). 
Addresses,INTACK, and CSa are sampled 
while AS is Low. 


CSo and CSI. Chip Select 0 (input, active 
Low) and Chip Select 1 (input, active High). 
CSa and CSl must be Low and High, respec- 
tively, in order to select a device. CSa is 
latched by AS. 


DS*. Data Strobe (input, active Low). DS pro- 
vides timing for the transfer of data into or out 
of the Z-CIO. 
lEI. Interrupt Enable In (input, active High). 
lEI is used with IEO to form an 'interrupt daisy 
chain when there is more than one interrupt- 
driven device. A High IEI indicates that no 
other higher priority device has an interrupt 
under service or is requesting an interrupt. 
lEO. Interrupt Enable Out (output, active 
High). IEO is High only if IEI is High and the 
CPU is not servicing an interrupt from the 
requesting Z-CIO or is not requesting an inter- 
rupt (Interrupt Acknowledge cycle only). lEO 
is connected to the next lower priority device's 
IEI input and thus inhibits interrupts from 
lower priority devices. 


'When As and iSS are detected Low at the same time (normally 
an illegal condition). the Z-CIO is reset. 


PAo-PA7. Port A I/O lines (bidirectional, 
3-state, or open-drain). These eight I/O lines 
transfer information between the Z-CIO's Port 
A and external devices. 


PBo-PB7. Port B I/O lines (bidirectional, 
3-state, or open-drain). These eight I/O lines 
transfer information between the Z-CIO's Port 
B and external devices. May also be used to . 
'provide external access to Counter/Timers 
1 and 2. 


PCc-PC3. Port C I/O lines (bidirectional, 
3-state, or open-drain). These four I/O lines 
are used to provide handshake, WAIT, and 
REQUEST lines for Ports.A and B or to provide 
external access to Counter/Timer 3 or access 
to the Z-CIO's Port C. 


PCLK. (input, TTL-compatible). This is a 
peripheral dock that may be, but is not 
necessarily, the CPU clock. It is used with 
. timers and REQUEST/WAIT logic. 
R/W. Read/Write (input). R/W indicates that 
the CPU is reading from (High) or writing to 


(Lo~) the Z-CIO. 


Architecture 
The Z8036 Z-CIO CounterlTimer and 
Z-Bus interface, threeI/O ports (two general- 
purpose 8-bit ports and one special-purpose 
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Parallel I/O element (Figure 3) consists of a 
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Figure 3. Z-CIO Block Diagram 
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Architecture 
(Continued) 
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4-bit port), three 16-bit counter/timers, an 
interrupt control logic block, and the internal 
control logic block. An extensive number of 
programmable options allow the user to tailor 
the configuration to best suit the specific 
application. 
The two general-purpose 8-bit I/O ports 
(Figure 4) are identical, except that Port B can 
be specified to provide external access to 
Counter/Timers 1 and 2. Either port can be 
programmed to be a handshake-driven, 
double-buffered port (input, output, or bidirec- 
tional) or a control-type port with the direction 
of each bit individually programmable. Each 
port includes pattern-recognition logic, allow- 
ing interrupt generation when a specific pat- 
tern is detected. The pattern-recognition logic 
can be programmed so the port functions like 
a priority-interrupt controller. Ports A and B 
can also be linked to form a 16-bit I/O port. 
To control these capabilities, both ports con- 
tain 12 registers. Thre~ of these registers, the 


INTERNAL 


OUTPUT 
DATA 


REGISTER 


PATIERN 
RECOGNITION 
LOGIC 
" 


INPUT 
DATA 


REGISTER 


PORT 
CONTROL 


LOGIC 


Input, Output, and Buffer registers, comprise 
the data path registers. Two registers, the 
Mode Specification and Handshake Specifica- 
tion registers, are used to define the mode of 
the port and to specify which handshake, if 
any, is to be used. The reference pattern for 
the pattern-recognition logic is defined via 
three registers: the Pattern Polarity, Pattern 
Transition, and Pattern Mask registers. The 
detailed characteristics of each bit path (for 
example, the direction of data flow or whether 
a path is inverting or noninverting) are pro- 
grammed using the Data Path Polarity, Data 
Direction, and Special I/O Control registers. 
The primary control and status bits are 
grouped in a single register, the Command 
and Status register, so that after the port is ini- 
tially configured, only this register must be 
accessed frequently. To facilitate initialization, 
the port logic is designed so that registers 
associated with an unrequired capability are 
ignored and do not have to be programmed. 


TO PORT C 
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Figure 4. Ports A and B Block Diagram 
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The function of the special-purpose 4-bit 
port, Port C (Figure 5), depends upon the 
roles of Ports A and B. Port C provides the 
required handshake lines. Any bits of Port C 
not used as handshake lines can be used as 
I/O lines or to provide external access for the 
third counter/timer. 


Since Port C's function is defined primarily 
by Ports A and B, only three registers (besides 
the Data Input and Output registers) are 
needed. These registers specify the details of 
each bit path: the Data Path Polarity, Data 
Direction, and Special I/O Control registers. 
The three counter/timers (Figure 6) are all 
identical. Each is comprised of a 16-bit down- 
counter, a 16-bit Time Constant register 
(which holds the value loaded into the down- 
counter), a 16-bit Current Counter register 
(used to read the contents of the down- 
counter), and two 8-bit registers for control 
and status (the Mode Specification and the 
Command and Status registers). 
The capabilities of the counter/timer are 


INTERNAL 


BUS 


OUTPUT 


DATA 
REGISTER 


INPUT 
DATA 
REGISTER 


numerous. Up to four port I/O lines can be 
dedicated as external access lines for each 
counter/timer: counter input, gate input, trig- 
ger input, and counter/timer output. Three dif- 
ferent counter/timer output duty cycles are 
available: pulse, one-shot, or square-wave. 
The operation of the counter/timer can be pro- 
grammed as either retriggerable or nonretrig- 
gerable. With these and other options, most 
counter/timer applications are covered. 
The interrupt control logic provides standard 


Z-Bus interrupt capabilities. There are five 
registers (Master Interrupt Control register, 
three Interrupt Vector registers, and the Cur- 
rent Vector register) associated with the inter- 
rupt logic. In addition, the ports' Command 
and Status registers and the counter/timers' 
Command and Status registers include bits 
associated with the interrupt logic. Each of 
these registers contains three bits for interrupt 
control and status: Interrupt Pending (IP), 
Interrupt Under Service (IUS), and Interrupt 
Enable (IE). 
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Figure 5. Port C Block Diagram 
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Figure 6. Counter/Timer Block Diagram 


The following describes the functions 
of the ports, pattern-recognition logic, 
counter/timers, and interrupt logic, 
I/O Port Operations. Of the Z-CIO's three 
I/O ports, two (Ports A and B) are general- 
purpose, and the third (Port C) is a special- 
purpose 4-bit port. Ports A and B can be con- 
figured as input, output, or bidirectional ports 
with handshake. (Four different handshakes 
are available.) They can also be linked to form 
a single 16-bit port. If they are not used as 
ports with handshake, they provide 16 input or 
output bits with the data direction pro- 
grammable on a bit-by-bit basis. Port B also 
provides access for Counter/Timers 1 and 2. In 
all configurations, Ports A and B can be pro- 
grammed to recognize specific data patterns 
and to generate interrupts when the pattern is 
encountered. 
The four bits of Port C provide the hand- 
shake lines for Ports A and B when required. 
A REQUESTIWAIT line can also be provided 
so that Z-CIO transfers can be synchronized 


I with DMAs or CPUs. Any Port C bits not used 
for handshake or REQUEST/WAIT can be used 
as input or output bits (indiVidually data direc- 
tion programmable) or external access lines for 
Counter/Timer 3. Port C does not contain any 
pattern-recognition logic. It is, however, 
capable of bit-addressable writes. With this 
feature, any' combination of bits can be set 
and/or cleared while the other bits 
remain undisturbed without first reading the 
register. 


Bit Port Operations. In bit port operations, the 


port's Data Direction register specifies the 
direction of data flow for each bit. A 1 
specifies an input bit, and a 0 specifies an out- 
put bit. If bits are used as I/O bits for a 
counter/timer, they should be set as input or 
output, as required. 
The Data Path Polarity register provides the 
capability of inverting the data path. A 1 
specifies inverting, and a 0 specifies non- 
inverting. All discussions of the port opera- 
tions assume that the path is noninverting. 
The value returned when reading an input 
bit reflects the state of the input just prior to 
the read. A l's catcher can be inserted into the 
input data path by programming a 1 to the 
corresponding bit position of the port's Special 
I/O Control register. When a 1 is detected at 
'the 1 's catcher input, its output is set to a 1 
until it is cleared. The l's catcher is cleared 
by writing a 0 to the bit. In all other cases, 
attempted writes to input bits are ignored. 
When Ports A and B include output bits, 
reading the Data register returns the value 
being output. Reads of Port C return the state 
of the pin. Outputs can be specified as open- 
drain by writing a 1 to the corresponding bit of 
the port's Special I/O Control register. Port C 
has the additional feature of bit-addressable 
writes. When writing to Port C, the four most 
significant bits are used as a write protect 
mask for the least significant bits (0-4, 1-5, 
2-6, and 3-7). If the write protect bit is written 
with aI, the state of the corresponding output 
bit is not changed. 
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Ports with Handshake Operation. Ports A and 
B can be specified as 8-bit input, output, or 
bidirectional ports with handshake. The Z-CIO 
provides four different handshakes for its 
ports: Interlocked, Strobed, Pulsed, and 
3-Wire. When specified as a port with hand- 
shake, the transfer of data into and out of the 
port and interrupt generation is under control 
of the handshake' logic. Port C provides the 
handshake lines as shown in Table 1. Any Port 
C lines not used for handshake can be used as 
simple I/O lines or as access lines for Counter/ 
Timer 3. 
When Ports A and B are configured as ports 
with handshake, they are double-buffered. 
This allows for more relaxed interrupt service 
routine response time. A second byte can be 
input to or output from the port before the 
interrupt for the first byte is serviced. Nor- 
mally, the Interrupt Pending (IP) bit is set and 
an interrupt is generated when data is shifted 
into the Input register (input port) or out of the 
Output register (output port). For input and 
output ports, the IP is automatically cleared 
when the data is read or written. In bidirec- 
tional ports, IP is cleared only by command. 
When the Interrupt on Two Bytes (ITB) control 
bit is set to I, interrupts are generated only 
when two bytes of data are available to be read 
or written. This allows a minimum of 16 bits of 
information to be transferred on each inter- 
rupt. With ITB set, the IP is not automatically 
cleared until the second byte of data is read or 
written. 
When the Single Buffer (SB) bit is set to I, 
the port acts as if it is only single-buffered. 
This is useful if the handshake line must be 
stopped on a byte-by-byte basis. 
Ports A and B can be linked to form a 16-bit 
port by programming a 1 in the Port Link Con- 
trol (PLC) bit. In this mode, only Port A's 
Handshake Specification and Command and 
Status registers are used. Port B must be 
specified as a bit port. When linked, only Port 


Port AlB Configuration. 
PCa 


Ports A and B: 
Bit Ports 
Bit I/O 


Port A: 
Input or Output Port 
~FD or DAV 


(Interlocked, Strobed, or Pulsed 
Handshake)· 


A has pattern-match capability. Port B's 
pattern-match capability must be disabled. 
Also, when the ports are linked, Port B's Data 
register must be read or written before 
Port A's. 
When a port is specified as a port with hand- 
shake, the type of port it is (input, output, or 
bidirectional) determines the direction of data 
flow. The data direction for the bidirectional 
port is determined by a bit in Port G (Tabie 1). 
In all cases, the contents of the Data Direction 
register are ignored. The contents of the 
Special I/O Control register apply only to out- 
put bits (3-state or open-drain). Inputs may not 
have l's catchers; therefore, those bits in the 
Special I/O Control register are ignored. Port 
C lines used for handshake should be pro- 
grammed as inputs. The handshake specifica- 
tion overrides Port C's Data Direction register 
for bits that must be outputs. The contents of 
Port C's Data Path Polarity register still apply. 


Interlocked Handshake. In the Interlocked 
Handshake mode, the action of the Z-CIO must 
be acknowledged by the external device 
before the next action can take place. Figure 7 
shows timing for Interlocked Handshake. An 
output port does not indicate that new data is 
available until the external device indicates it 
is ready for the data. Similarly, an input port 
does not indicate that it is ready for new data 
until the data source indicates that the pre- 
vious byte of the data is no longer available, 
thereby acknowledging the input port's accep- 
tance of the last byte. This allows the Z-CIO to 
interface directly to the port of a Z8 microcom- 
puter, a UPC, an FlO, an FIFO, or to another 
Z-CIO port with no external logic. 
A 4-bit deskew timer can be inserted in the 
Data Available (DAV) output for output po~ts. 
As data is transferred to the Buffer register, 
the deskew timer is triggered. After the 
number of PCLK cycles speCified by the 
deskew timer ti~e constant plus one, DAV is 


P~ 
PCI 
PCO 


Bit I/O 
Bit I/O 
Bit I/O 


ACKIN 
REQUESTIW AIT 
Bit I/O 


or Bit I/O 


Port B: 
Input or Output Port 
REQUESTIWAIT 
Bit I/O 
RFD or DAV 
ACKIN 
(Interlocked, Strobed, or Pulsed 
or Bit I/O 


Handshake)· 


Port A or B: 
Input Port (3-Wire 
RFD (Output) 
DAV (Input) 
REQUESTIW AIT 
DAC (Output) 
Handshake) 
or Bit I/O 


Port A or B: 
Output Port (3-Wire 
DA V (Output) 
DAC (Input) 
REQUESTIW AIT 
RFD (Input) 


H~ndshake) 
or Bit I/O 


Port A or B: 
Bidirectional Port 
RFD or DAV 
ACKIN 
REQUESTIW AIT 
IN/OUT 


(Interlocked or Strobed Handshake) 
or Bit I/O 


"Both Ports A and B can be specified input or output with Interlocked, Strobed, or Pulsed Handshake at the same time if neither 
uses REQUESTIWAIT. 


Table 1. Port C Bit Utilization 
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allowed to go Low. The deskew timer therefore 
guarantees that the output'data is valid for a 
specified minimum amount of time before DA V 
goes Low. Deskew timers are available for out- 
put ports independent of the type of handshake 
employed. 


Strobed Handshake. In the Strobed Hand- 
shake mode, data is "strobed" into or out of 
the port by the external logic. The falling edge 
of the Acknowledge Input (ACKIN) strobes 
data into or out of the port. Figure 7 shows 
timing for the Strobed Handshake. In contrast 
to the Interlocked Handshake, the signal 
indicating the port is ready for another data 
transfer operates independently of the ACKIN 
input. It is up to the external logic.to ensure 
that data overflows or underflows do not occur. 


3-Wire Handshake. The 3-Wire Handshake is 
designed for the situation in which one output 
port is communicating with many input ports 
simultaneously. It is essentially the same as the 
Interlocked Handshake, except that two signals 
are used to indicate if an input port is ready 
for new data or if it has accepted the present 
data. In the 3-Wire Handshake (Figure 8), the 
rising edge of one status line indicates that the 
port is ready for data, and the rising edge of 
another status line indicates that the data has 
been accepted. With the 3-Wire Handshake, 
the output lines of many input ports can be 
bussed together with open-drain drivers; the 


INPUT HANDSHAKE 


DATA:J< 
VALID 
X'-________ _ 


RFD 


DATA LATCHED 
IN BUFFER REGISTER 


output port knows when all the ports have 
accepted the data and are ready. This is the 
same handshake as is used on the IEEE-488 
bus. Because this handshake requires three 
lines, only one port (either A or B) can be a 
3-Wire Handshake port at a time. The 3-Wire 
Handshake is not available in the bidirectional 
mode. Because the port's direction can be 
changed under software control, however, 
bidirectional IEEE-488-type transfers can be 
performed. 


Pulsed Handshake. The Pulsed Handshake 
(Figure 9) is designed to interface to 
mechanical-type devices that require data to 
be held for long periods of time and need 
relatively wide pulses to gate the data into or 
out of the device. The logic is the same as the 
Interlocked Handshake mode, except that an 
internal counter/timer is linked to the hand- 
shake logic. If the port is specified in the input 
mode, the timer is inserted in the. ACKIN path. 
The external ACKIN input trigg-ars the timer 
and its output is used as the Interlocked Hand- 
shake's normal acknowledge input. If the port 
is an output port, the timer is placed in the 
Data Available (DAV) output path. The timer is 
triggered when the normal Interlocked Hand- 
shake DAV output goes Low and the timer out- 
put is used as the actual DAV output. The 
counter/timer maintains all of its normal 
capabilities. This handshake is not available to 
bidirectional ports. 


OUTPUT HANDSHAKE 
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BUFFER REGISTER 
"EMPTIED" 


NEXT BYTE 


NEXT BYTE 
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STROBED 
HANDSHAKE' 


SHIFTED FROM 
OUTPUT REGISTER TO 
BUFFER REGISTER 


INTERLOCKED 
¥HANDSHAKE 


Figuro 7. Intorlockod and Strobod Handshakes 
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OUTPUT HANDSHAKE 
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Figuro 8. 3-Wiro Handshako 
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REQUEST/WAIT Line Operation. Port C can 
be programmed to provide a status signal out- 
put in addition to the normal handshake lines 
for either Port A or B when used as a port with 
handshake. The additional signal is either a 
REQUEST or WAIT signal. The REQUEST 
signal indicates when a port is ready to per- 
form a data transfer via the Z-Bus. It is 
intended for use with a DMA-type device. The 
WAIT signal provides synchronization for 
transfers with a CPU. Three bits in the Port 
Handshake Specification register provide con- 
trols for the REQUEST/WAIT logic. Because 
the extra Port C line is used, only one port can 
be specified as a port with a. handshake and a 
REQUEST/WAIT line. The other port must be 
a bit port .. 
Operation of the REQUEST line is modified 
by the state of the port's Interrupt on Two 
Bytes (ITB) control bit. When ITB is 0, the 
REQUEST line goes active as soon as the 
Z-CIO is ready for a data transfer. If ITB is I, 
REQUEST does not go active until two bytes 
can be transferred. REQUEST stays active as 
long as a byte is availabre to be read or 
written. 
The SPECIAL REQUEST function is reserved 
for use with bidirectional ports only. In this 
case, the REQUEST line indicates the status of 
the register not being used in the data path at 
that time. If the IN/OUT line is High, the 
REQUEST line is High when the Output 
register is empty. If IN/OUT is Low, the 
REQUEST line is High when the Input register 
is full. 
Pattern-Recognition Logic Operation. Both 
Ports A and B can be programmed to generate 
interrupts when a specific pattern is recog- 
nized at the port. The pattern-recognition logic 
is independent of the port application, thereby 
allOWing the port to recognize patterns in all of 
its configurations. The pattern can be 
independently ·specified for each bit as I, 0, 
rising edge, falling edge, or any transition. 
Individual bits may be masked off. A pattern- 
match is defined as the simultane.ous satisfac- 
tion of all nonmasked bit specifications in the 
AND mode or the satisfaction of any non- 
masked bit specifications in either of the OR or 
OR-Priority Encoded Vector modes. 


INPUT PORT 


ACKIN 


(EXTERNAL) 
D-t> 


ACKIN 
(INTERNAL) 
r-., 


'------' .... ~~ I 


OUTPUT PORT 


Figure 9. Pulsed Handshake 


The pattern specified in the Pattern Defini- 
tion register assumes that the data path is pro- 
grammed to be noninverting. If an input bit in 
the data path is programmed to be inverting, 
the pattern detected is the opposite of the one 
speCified. Output bits used in the pattern- 
match logic are internally sampled before the 
invertlnoninvert logic. 


Bit Port Pattern-Recognition Operations. Dur- 
ing bit port operations, pattern-recognition 
may be performed on all bits, including those 
used as I/O for the counter/timers. The input 
to the pattern-recognition logic follows the 
value at the pins (through the invertlnoninvert 
logic) in all cases except for simple inputs with 
l's catchers. In this case, the output of the l's 
catcher is used. When operating in the AND 
or OR mode, it is the transition from a no- 
match to a match state that causes the inter- 
rupt. In the "OR" mode, if a second match 
occurs before the first match goes away, it 
does not cause an interrupt. Since a match 
condition only lasts a short time when edges 
are specified, care must be taken to avoid 
losing a match condition. Bit ports speCified in 
the OR-Priority Encoded Vector mode generate 
interrupts as long as any match state exists. A 
transition from a no-match to a match state is 
not required. 
The pattern-recognition logic of bit ports 
operates in two basic modes: Transparent and 
Latched. When the Latch on Pattern Match 
(LPM) bit is set to 0 (Transparent mode), the 
interrupt indicates that a specified pattern has 
occurred, but a read of the Data register does 
not necessarily indicate the state of the port at 
the time the interrupt was generated. In the 
Latched mode (LPM = 1), the state of all the 
port inputs at the time the interrupt was gener- 
ated is latched in the input register and held 
until IP is cleared. In all cases, the PMF indi- 
cates the state of the port at the time it is read. 
If a match occurs while IP is already set, an 
error condition exists. If the Interrupt On Error 
bit (IOE) is 0, the match is ignored. However, 
if IOE is I, after the first IP is cleared, it is 
automatically set to 1 along with the Interrupt 
Error (ERR) flag. Matches occurring while ERR 
is set are ignored. ERR is cleared when the 
corresponding IP is cleared. 
When a pattern-match is present in the 


OR-Priority Encoded Vector mode, IP is set to 
1. The IP cannot be cleared until a match is no 
longer present. If the interrupt vector is 
allowed to include status, the vector returned 
during Interrupt Acknowledge indicates the 
highest priority bit matching its speCification at 
the time of the Acknowledge cycle. Bit 7 is the 
highest priority and bit 0 is the lowest. The bit 
initially causing the interrupt may not be the 
one indicated by the vector if a higher priority 
bit matches before the Acknowledge. Once the 
Acknowledge cycle is initiated, the vector is 
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. frozen until the corresponding IP is cleared. 
Where inputs that cause interrupts might 
change before the interrupt is serviced, the l's 
catcher can be used to hold the value. 
Because a no-match to match transition is not 
required, the source of the interrupt must be 
cleared before IP is cleared or else a second 
interrupt is generated. No error detection is 
performed in this mode and the Interrupt On 
Error bit should be set to O. 


Ports with Handshake Pattern::Recognition 
Operation. In this mode, the handshake logic 
normally controls the setting of IP and, 
therefore, the generation of interrupt requests. 
The pattern-match logic controls the Pattern 
Match Flag (PMF). The data is compared with 
the match pattern when it is shifted from the 
Buffer register to the Input register (input port) 
or when it is shifted from the Output register to 
the Buffer register (output port). The pattern- 
match logic can override the handshake logic 
in certain situations. If the port is programmed 
to interrupt when two bytes of data are 
available to be read or written, but the first 
byte matches the specified pattern, the 
pattern-recognition logic sets IP and generates 
an interrupt. While PMF is set, IP cannot be 
cleared by reading or writing the data 
registers. IP must be cleared by command. 
The input register is not emptied while IP is 
set, nor is the output register filled until IP is 
cleared. 
If the Interrupt on Match Only (IMO) bit is 
set, IP is set only when the data matches the 
pattern. This is useful in DMA-type applica- 
tions when interrupts are required only after a 
block of data is transferred. 


Counter ITimer. Operation. The three 
independent 16-bit counter/timers consist of a 
presettable 16-bit down counter, a 16-bit Time 
Constant register, a 16-bit Current Counter 
register, an 8-bit Mode SpeCification register, 
an 8-bit Command and Status register, and the 
associated control logic that links these 
registers. 


PCLK/2 OR 
COUNTER INPUT 


TRIGGER --1 


GATE 
LJ 


Function 
C/Tl 
C/T2 
C/T3 


CounterlTimer Output 
PB 4 
PB a 
pca 


Counter Input 
PB 5 
PB 1 
PC 1 


Trigger Input 
PB 6 
PB 2 
PC2 


Gate Input 
PB 7 
PB 3 
PC3 


Table 2. Counter/Timer External Access 


The flexibility of the counter/timers is 
enhanced by the provision of up to four lines 
per counter/timer (counter input, gate 'input, 
trigger input, and counter/timer output) for 
direct external control and status. Counter/ 
Timer lis external I/O lines are provided by 
the four most significant bits of Port B. 
Counter/Timer 2' s are provided by the four 
least significant bits of Port B. Counter/Timer 
3' s external I/O lines are provided by the four 
bits of Port C. The utilization of these lines 
(Table 2) is programmable on a bit-by-bit basis 
via the Counter/Timer Mode Specification 
registers. 
When external counter/timer I/O lines are to 
be used, the associated port lines must be 
vacant and programmed in the proper data 
direction. Lines used for counter/timer I/O 
have the same characteristics as simple input 
lines. They can be specified as inverting or 
noninverting; they can be read and used with 
the pattern-recognition logic. They can also 
include the l's catcher input. 
Counter/Timers 1 and 2 can be linked inter- 
nally in three different ways. Counter/Timer 
l's output (inverted) can be used as Counter/ 
Timer 2's trigger, gate, or counter input. 
When linked, the counter/timers have the 
same capabilities as when used separately. The 
only restriction is that when Counter/Timer 1 
drives Counter/Timer 2's count input, 
Counter/Timer 2 must be programmed with 
its external count input disabled. 
There are three duty cycles available for the 
timer/counter output: pulse, one-shot, and 
square-wave. Figure 10 shows the counter/ 
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Figure 10. Counter/Timer Waveforms 
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timer waveforms. When the Pulse mode is 
specified, the output goes High for one clock 
cycle, beginning when the down-counter 
leaves the count of 1. In the One-Shot mode; 
the output goes High when the counter/timer is 
triggered and goes Low when the down- 
counter reaches O. When the square-wave out- 
put duty cycle is specified, the counter/timer 
goes through two full sequences for each 
cycle. The initial trigger causes the down- 
counter· to be loaded and the normal count- 
down sequence to begin. If ,a 1 count is 
detected on the down-counter's clocking edge, 
the output goes High and the time constant 
value is reloaded. On the clocking edge, when 
both the down-counter and the output are l's, 
the output is pulled back Low. 
The Continuous/Single Cycle (C/SC) bit in 
the Mode Specification register controls opera- 
tion of the down~counter when it reaches ter- 
minal count. If C/SC is 0 when a terminal 
count is reached, the countdown sequence 
'stops. If the C/SC bit is 1 each time the count- 
down counter reaches 1, the next cycle causes 
the time constant value to be reloaded. The 
time constant value may be changed by the 
CPU, and on reload, the new time constant 
value is loaded. 
Counter/timer operations require loading the 
time constant value in the Time Constant 
register c;md initiating the countdown sequence 
by loading the down-counter with the time 
constant value. The Time Constant register is 
accessed as two 8-bit registers. The registers 
are readable as well as writable, and the 
access order is irrelevant. A 0 in the Time 
Constant register specifies a time constant of 
65,536. The down-counter is loaded in one of 
three ways: by writing a 1 to the Trigger 
Command Bit (TCB) of the Command and 
Status register, on the rising edge of the exter- 
nal trigger input, or, for Counter/Timer 2 only, 
on the rising edge of Counter/Timer l's inter- 
nal output if the counters are linked via the 
trigger input. The TCB is write-only, and read 
always returns O. 
' 


Once the down-counter is loaded, the count- 
down sequence continues toward terminal 
count as long as all the counter/timers' hard- 
ware and software gate inputs are High. If any 
of the gate inputs goes Low (0), the countdown 
halts. It resumes when all gate inputs are 1 
again. 
The reaction to triggers occurring during a 
countdown sequence is determined by the state 
of the Retrigger Enable Bit (REB) in the Mode 
Specification register. If REB is 0, retriggers 
are ignored and the countdown continues nor- 
mally. If REB is I, each trigger causes the 
down-counter to be reloaded and the count- 
down sequence starts over again. If the output 


is programmed in the Square-Wave mode, 
retrigger causes the sequence to start over 
from the initial load of the time constant. 
The rate at which the down-counter counts is 
determined by the mode of the counter/timer. 
In the Timer mode (the External Count Enable 
[ECE] bit is 0), the down-counter is clocked 
internally by a signal that is half the frequency 
of the PCLK input to the chip. In the Counter 
mode (ECE is I), the down-counter is 
decremented on the rising edge of the counter/ 
timer's counter input. 
Each time the counter reaches terminal 
count, its Interrupt Pending (IP) bit is set to 1, 
and if interrupts are enabled (IE = 1), an inter- 
rupt is generated. If a terminal count occurs 
while IP is already set, an internal error flag is 
set. As soon as IP is cleared, it is forced to a 1 
along with the Interrupt Error (ERR) flag. 
Errors that occur after the internal flag is set 
are ignored. 
The state of the down-counter can be deter- 
mined in two ways: by reading the contents of 
the down-counter via the Current Count 
register or by testing the Count In Progress 
(CIP) status bit in the Command and Status 
register. The CIP status bit is set when the 
down-counter is loaded; it is reset when the 
down-counter reaches O. The Current Count 
register is a 16-bit register, accessible as two 
8-bit registers, which mirrors the contents of 
the down-counter. This register can be read 
anytime. 'However, reading the register is 
asynchronous to the counter's counting, and 
the value returned is valid only if the counter 
is stopped. The down-counter can be reliably 
read "on the fly" by the first writing of a 1 .to 
the Read Counter Control (RCC) bit in the 
counter/timer's Command and Status register. 
This freezes the value in the Current Count 
register until a read of the least significant 
byte is performed. 


Interrupt Logic Operation. The interrupts 
generated by the Z-CIO follow the Z-Bus 
operation as described more fully in the Zilog 
Z-Bus Summary. The Z-CIO has five potential 
sources of interrupts: the three counter/timers 
and Ports A and B. The priorities of these 
. 


sources are fixed in the following order: 
Counter/Timer 3, Port A, Counter/Timer 2, 
Port B, and Counter/Timer 1. Since the 
counter/timers all have equal capabilities and 
Ports A and B have equal capabilities, there is 
no adverse impact from the relative priorities. 
The Z-CIO interrupt priority, relative to 
other components within the system, is deter- 
mined by an interrupt daisy chain. Two pins, 
Interrupt Enable In (IEI) and Interrupt Enable 
Out (lEO), provide the input and output 
necessary to implement the daisy chain. When 
IEI is pulled Low by a higher priority device, 
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the Z-CIO cannot request an interrupt of the 
CPU. The following discussion assumes that 
the IEI line is High. 
Each source of interrupt in the Z-CIO con- 
tains three bits for the control and status of the 
interrupt logic: an Interrupt Pending (IP) 
status bit, an Interrupt Unde.r Service (IUS) 
status bit, and an Interrupt Enable (IE) control 
bit. IP is set when an event requiring CPU 
intervention occurs. The setting of IP results in 
forcing the Interrupt (INT) output Low, if the 
associated IE is 1. 
The IUS status bit is set as a result of the 
Interrupt Acknowledge cycle by the CPU and 
is set only if its IP is of highest priority at the 
time the Interrupt Acknowledge commences. It 
can also be set directly by the CPU. Its 
primary function is to control the interrupt 
daisy chain. When set, it disables lower prior- 
ity sources in the daisy chain, so that lower 
priority interrupt sources do not request ser- 
vicing while higher priority devices are being 
serviced. 
The IE bit provides the CPU with a means of 
masking off individual SQurces of interrupts. 
When IE is set to I, an interrupt is generated 
normally. When IE is set to a, the IP bit is set 
when an event occurs that would normally 
require service; however, the INT output is not 
forced Low. 
The Master Interrupt Enable (MIE) bit allows 
all sources of interrupts within the Z-CIO to be 
disabled without having to individually set 
' 


each IE to O. If MIE is set to a, all IPs are 
masked off and no interrupt can be requested 
or acknowledged. The Disable Lower Chain 


Programming 
Programming the Z-CIO entails loading con- 
trol registers with bits to implement the desired 
operation. Individual enable bits are prOVided 
for the various major blocks so that erroneous 
operations do not occur while the part is being 
initialized. Before the ports are enabled, IPs 
cannot be set, REQUEST and WAIT cannot be 
asserted, and all outputs remain high-impe- 
dance. The handshake lines are ignored until 
Port C is enabled. The counter/timers cannot 
be triggered until their enable bits are set. 
The Z-CIO is reset by forcing AS and DS 


Low Simultaneously or by writing a 1 to the 
Reset bit. Once reset, the only thing that can 
be done is to read and write the Reset bit. 
Writes to all other bits are ignored and all 
reads return as. In this state, all control bits 
are forced to O. Only after clearing the Reset 


(DLC) bit is included to allow the CPU to 
modify the system daisy chain. When the DLC 
bit is set to I, the Z-CIO's lEO is forced Low, 
independent of the state of the Z-CIO or its IEI 
input, and all lower priority devices' interrupts 
are disabled. 
As part of the Interrupt Acknowledge cycle, 
the Z-CIO is capable of responding with an 
8-bit interrupt vector that specifies the source 
of the interrupt. The Z-CIO contains three vec- 
tor registers: one for Port A, one for Port B, 
and one shared by the three counter/timers. 
The vector output is inhibited by setting the No 
Vector (NV) control bit to 1. The vector output 
can be modified to include status information 
to pinpoint more precisely the cause of inter- 
rupt. Whether the vector includes status or not 
is controlled by a Vector Includes Status (VIS) 
control bit. Each base vector has its own VIS 
bit and is controlled independently. When 
MIE = I, reading the base vector register 
always includes status, independent of the 
state of the VIS bit. In this way, all the infor- 
mation obtained by the vector, including 
status, can be obtained with one additional 
instruction when VIS is set to o. When 
MIE = 0, reading the vector register returns 
the unmodified base vector so that it can be 
verified. Another register, the Current Vector 
register, allows use of the Z-CIO in a polled 
environment. When read, the data returned is 
the same as the interrupt vector that would be 
output in an acknowledge, based on the 
highest priority IP set. If no unmasked IPs are 
set, the value FFH is returned. The Current 
Vector register is read-only. 


bit (by writing to it) can the other command 
bits be programmed. 
Register Addressing. The Z-CIO allows two 
schemes for register addressing. Both schemes 
use only six of the eight bits of the address/ 
data bus. The scheme used is determined by 
the Right Justify Address (RJA) bit in the 
Master Interrupt Control register. When RJA 
equals 0, address bus bits a and 7 are ignored, 
and bits 1 through 6 are decoded for the 
register address (Ao from ADl). When RJA 
equals I, bits a through 5 are decoded for the 
register address (Ao from ADo). In the follow- 
ing register descriptions, only six bits are 
shown for addresses and represent address/ 
data bus bits a through 5 or 1 through 6, 
depending on the state of the RJA bit. 
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Registers 
Master Interrupt Control Regi~ter 


Address: 000000 


(ReadlWrite) 


MAST~R INTERRUPT ~~ 
ENABLE (MIE) 
\ 


DISABLE LOWER CHAIN (DLC) 


NO VECTOR (NV) 


PORT A VECTOR INCLUDES 
STATUS (PA VIS) 
~ 


~RESET 


RIGHT JUSTIFIED ADDRESSES 
0= SHIFT LEFT (Ao from AD,) 
1 = RIGHT JUSTIFY (Ao from ADo) 


COUNTERITIMERS VECTOR 
INCLUDES STATUS (CT VIS) 


PORT B VECTOR INCLUDES 
STATUS (PB VIS) 


Master Configuration Control Register 
Address: 000001 


(ReadlWrite) 


PORTB~ 
JJ 
ENABLE (PBE) 


COUNTERITIMER 1 
ENABLE (CT1E) 


COUNTERITIMER 2 
ENABLE (CT2E) 


PORT C AND COUNTERI 
TIMER 3 ENABLE 
(PCE AND CT3E) 


I L 'O"",'M'.""", 
CONTROLS (LC) 


LCl 
LCO 
--0 -0 COUNTERITIMERS INDEPENDENT 


o 
1 
CIT 1'5 OUTPUT GATES CIT 2 
1 
·0 
CIT l's OUTPUT TRIGGERS CIT 2 
1 
1 
CIT 1'5 OUTPUT IS CIT 2's 
.COUNT INPUT 


PORT A ENABLE (PAE) 


L-___ PORT LINK CONTROL (PLC) 


0= PORTS A AND B OPERATE INDEPENDENTLY 
1 = PORTS A AND B ARE LINKED 


Figure 11. Master Control Registers 


Port Mode Specification Registers 
Addresses: 100000 Port A 


Port Handshake Specification Registers 
Addresses: 100001 Port A 
10 1 000 Port B 
(ReadIW rite) 


101001 Port B 
(ReadlWrite) 


I~I~I~I~I~I~I~I~I 


PORTTYPE~ 
SELECTS (PTS) 


PTSl PTSO. 
[) [) 
BIT PORT 


o 
1 
INPUT PORT 


1 
0 
OUTPUT PORT 


1 
1 
BIDIRECTIONAL 
PORT 


INTERRUPT ON TWO 
L 


LATCH ON PATIERN MATCH (LPM) 
(BIT MODE) 
DESKEW TIMER ENABLE (DTE) 
(HANDSHAKE MODES) 


PATIERN MODE SPECIFICATION 
BITS (PMS) 


PMSl PMSO 


o 
0 
DISABLE PATIERN MATCH 
o 
1 
"AND"MODE 


HANDSHAKE TYPE SPECIFICAT. ION:J 
. I ---c ""'" n."",,,,,,,,o, 
BITS (HSn 
BITS 


HSTl HSTO 
~~~~~~~I~~~ ~~:~s C~NSTANT. 


o 
0 
INTERLOCKED HANDSHAKE 
LSB IS FORCED 1. 
o 
1 
STROBED HANDSHAKE 


1 
0 
PULSED HANDSHAKE 
. 
1 
1 
THREE·WIRE HANDSHAKE 


REQUESTIWAIT SPECIFICATION BITS 
. 
BYTES (IT B) 


SINGLE BUFFERED 
MODE (SB) 
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1 
0 
"OR" MODE 
(RWS) 


1 
1 
"OR·PRIORITY ENCODED 
VECTOR" MODE 
RWS2 
RWS1 
RWSO FUNCTION 


o 
-0- REQUESTIWAIT DISABLED 
'----- INTERRUPT ON MATCH ONLY (IMO) 
o 
1 
OUTPUT WAIT 


1 
1 
INPUT WAIT 


o 
0 
SPECIAL REQUEST 


o 
1 
OUTPUT REQUEST 


1 
1 
INPUT REQUEST 


Port Command and Status Registers 
Addresses: 001000 Port A 


001001 Port B 
(Read/Partial Write) 


INTERRUPT UNDER 
SERVICE (IUS) 


INTERRUPT ENABLE (IE) 


INTERRUPT PENDING (IP) 


IUS, IE, AND IP ARE WRITIEN USING 


THE FOLLOWING CODE: 


NULL CODE 


CLEAR IP & IUS 


SET IUS 


CLEAR IUS 


SET IP 


CLEAR·IP 


SET IE 


CLEAR IE 


o 0 
0 


o 0 
1 
o 1 
0 


o 1 
1 


1 
0 
0 


1 
0 
1 


1 
1 
0 


1 
1 
1 


INTERRUPT ERROR (ERR) ----' 


(READ ONLy) 


~ 
. 


. I L INTERRUPT ON ERROR (IOE) 
L PATIERN MATCH FLAG (PMF) 
(READ ONLy) 


INPUT REGISTER FULL (lRF) 
(READ ONLy) 


OUTPU'T REGISTER EMPTY (ORE) 
(READ ONLy) 


Figure 12. Port Specification Registers 


2014-009, 010 


Registers 
(Continued) 


2014-011, 012, 013 


Data Path Polarity Registers 
Addresses: 100010 Port A 


101010 Port B 


000101 Port C (4 LSBs only) 
(ReadlWrite) 


Data Direction Registers 
Addresses: 100011 Port A 
101011 Port B 


000110 Port C (4 LSBs only) 
(ReadlWrite) 


'----- DATA PATH POLARITY (DPP) 


0" NON·INVERTING 
'----- DATA DIRECTION (DO) 


O=OUTPUT BIT 


1 = INVERTING 
1 =INPUT BIT 


Special I/O Control Registers 
Addresses: 100100 Port A 


101100 Port B 


000111 Port·C (4 LSBs only) 
(ReadlWrite) 


'----- SPECIAL INPUT/OUTPUT (SIO) 
0= NORMAL INPUT OR OUTPUT 
1 =OUTPUT WITH OPEN DRAIN OR 
INPUT WITH l's CATCHER 


Figure 13. Bit Path Definition Registers 


Port· Data Registers 
Addresses: 001101 Port A 


001110 Port B 
(ReadlWrite) 


Pattern Polarity Registers (PP) 


Addresses: 100101 Port A 
101101 Port B 
(ReadlWrite) 


Pattern Transition Registers (PT) 


Addresses: 100110 Port A 
101110 Porf B 
(ReadlWrite) 


Pattern Mask Registers (PM) 


Addresses: 100111 Port A 
101111 Port B 
(ReadlWrite) 


Figure 14. Port Data Registers 


Port C Data Register 
Address: 001111 


(ReadlWrite) 


4 MSBs 
O. WRITING OF CORRESPONDING LSB ENABLED 
1 _ WRITING OF CORRESPONDING LSB INHIBITED 


(READ RETURNS 1) 


PM PT PP PATIERN SPECIFICATION 
0" 0" X BIT MASKED OFF 
o 1 
X 
ANY TRANSITION 


1 
0 
0 
ZERO 


1 
0 
lONE 


1 
1 
0 
ONE·TO·ZERO TRANSITION (\) 


1 
1 
1 
ZERO·TO·ONE TRANSITION (I) 


Figure 15. Pattern Definition Registers 
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Registers 
(Continued) 
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Counter/Timer Command and Status Registers 
Addresses: 001010 Counter/Timer 1 


001011 Counter/Timer 2 
001100 Counter/Timer 3 
(Read/Partial Write) 


'""''"'' "'"'" ",." """ l I I 
INTERRUPT ENABLE (IE) 
I 
I 


INTERRUPT PENDING (lP) 
I 
I 


IUS, IE, AND IP ARE WRITIEN USING 


THE FOLLOWING CODE: 


NULL CODE 


CLEAR IP & IUS 


SET IUS 


CLEAR IUS 


SET IP 


CLEAR IP 
1 
0 
1 


SET IE 
1 
1 
0 


CLEAR IE 
1 
1 
1 


INTERRUPT ERROR (ERR) ___ 
---1 


(READ ONLy) 


E~ 


COUNT IN PROGRESS (CIP) 
(READ ONLy) 


TRIGGER COMMAND BIT (TCB) 
(WRITE ONLY· READ RETURNS 0) 


GATE COMMAND BIT (GCB) 


READ COUNTER CONTROl: (RCC) 
(READISET ONLY- 
CLEARED BY READING CCR LSB) 


Counter/Timer Mode Specification Registers 
Addresses: 011100 Counter/Timer 1 


011101 Counter/Timer 2 
011110 Counter/Timer 3 
(Read/Write) 


CONTINUOUS S.lli.~ 
J~ 
GLE CYCLE (CISC) 


EXTERNAL OUTPUT 


ENABLE (EOE) 


EXTERNAL COUNT 


ENABLE (ECE) 


EXTERNAL TRIGGER 


ENABLE (ETE) 


I L 
,""mon '"'' 
SELECTS (DCS) 
• 


DCS1DCSO 
----0- ----0- PULSE OUTPUT 
o 
1 
ONE·SHOT OUTPUT 


1 
0 
SQUARE·WAVE OUTPUT 


1 
1 
DO NOT SPECIFY 


RETRIGGER ENABLE BIT (REB) 


L..-. ___ EXTERNAL GATE ENABLE (EGE) 


Counter/Timer Current Count Registers 
Addresses: 010000 Counter/Timer l's MSB 
010001.Counter/Timer l's LSB 
010010 Counter/Timer 2's MSB 
010011 Counter/Timer 2's LSB 
010100 Counter/Timer 3's MSB 
010101 Counter/Timer 3's LSB 


MOST -----' 
SIGNIFICANT 


BYTE 


(Read Only) 


'------ LEAST 
SIGNIFICANT 
BYTE 


Counter/Timer Time Constant Registers 
Addresses: 010110 Counter/Timer l's MSB 
010111 Counter/Timer l's LSB 
011000 Counter/Timer 2's MSB 
011001 Counter/Timer 2's LSB 
011010 Counter/Timer 3's MSB 
011011 C'ounter/Timer 3's LSB 


MOST-------' 
SIGNIFICANT 


BYTE 


(Read/Write) 


'------ LEAST 
SIGNIFICANT 
BYTE 


Figure 16. Conter/Timer Registers 


2014-014 


Registers 
(Continued) 


Register 
Address 
Summary 


2014·015 


Interrupt Vector Register 
Addresses: 000010 Port A 


000011 Port B 
000100 Counter/Timers 
(ReacllWrite) 


L..-___ INTERRUPT VECTOR 


PORT VECTOR STATUS 


PRIORITY ENCODED VECTOR MODE: 


NUMBER OF HIGHEST PRIORITY BIT 
WITH A MATCH 


ALL OTHER MODES: 
03 
02 
01 
ORE iRF PMF NORMAL 
o 
0 
0 
ERROR 


COUNTERfTlMER STATUS 


02 01 
0' 0' 
CfT3 
o 1 
CfT 2 
1 
0 
CfT 1 
1 
1 
ERROR 


Current Vector Register 
Address: 011111 


(Read Only) 


L..-___ INTERRUPT VECTOR BASED 
ON HIGHEST PRIORITY 
UNMASKED IP. 
IF NO INTERRUPT PENDING 
ALL 1's OUTPUT. 


Figure 17. Interrupt Vector Registers 


Address' 
000000 
000001 
000010 
000011 
000100 
000101 
000110 
000111 


Address· 
001000 
001001 
001010 
001011 
001100 
001101 
001110 
001111 


Address· 
010000 
010001 
010010 
010011 
010100 
010101 
010110 
010111 
011000 
011001 
011010 
011011 
011100 
011101 
011110 
011111 


Main Control Registers 
Register Name 
Master Interrupt Control 
Master Configuration Control 
Port A's Interrupt Vector 
Port B's Interrupt Vector 
CounterlTimer's Interrupt Vector 
Port C's Data Path Polarity 
Port C's Data Direction 
Port C's Special I/O Control 


Most Often Accessed Registers 
Register Name 
Port A's Command and Status 
Port B's Command and Status 
CounterlTimer l's Command and Status 
Counter/Timer 2's Command and Status 
Counter/Timer 3's Command and Status 
Port A's Data 
Port B's Data 
Port C's Data 


Counter/Timer Related Registers 
Register Name 
Counter/Timer 1 's Current Count-MSBs 
Counter/Timer l's Current Count-LSBs 
Counter/Timer 2's Current Count-MSBs 
CounterlTimer 2's Current Count-LSBs 
Counter/Timer 3's Current Count-MSBs 
Counter/Timer 3's Current Count-LSBs 
Counter/Timer 1's Time Constant-MSBs 
Counter/Timer l's Time Constant-LSBs 
Counter/Timer 2's Time Constant-MSBs 
Counter/Timer 2's Time Constant-LSBs 
Counter/Timer 3's Time Constant-MSBs 
Counter/Timer 3's Time Constant-LSBs 
Counter/Timer l's Mode SpeCification 
Counter/Timer 2's Mode Specification 
CounterlTimer 3's Mode Specification 
Current Vector 


'When RIA = 0, AO from AD1; when RIA = 1, AO from ADO 


Address·" 


100000 
100001 
100010 
100011 
100100 
100101 
100110 
100111 


Address· 
101000 
101001 
101010 
101011 
101100 
101101 
101110 
101111 


Port A Specification Registers 
Register Name 
Port A's Mode Specification 
Port A's Handshake Specification 
Port A's Data Path Polarity 
Port A's Data Direction 
Port A's Special I/O Control 
Port A's Pattern Polarity 
Port A's Pattern Transition 
Port A's Pattern Mask 


Port B Specification Registers 
Register Name 
Port B's Mode Specification 
Port B's Handshake Specification 
Port B's Data Path Polarity 
Port B's Data Direction 
Port B's Special I/O Control 
Port B's Pattern Polarity 
Port B's Pattern Transition 
Port B's Pattern Mask 
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Timing 
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Read Cycle. The CPU places an address on 
the address/data bus. The more significant bits 
and status information are combined and 
decoded by external logic to provide two Chip 
Selects (CSa and CSl). Six bits of the least 
significant byte of the address are latched 
within the Z-CIO and used to specify a Z-CIO 
register. The data from the register specified is 
strobed onto the address/data bus when the 
CPU issues a Data Strobe (DS). If the register 
indicated by the address does not exist, the 
Z-CIO remains high-impedance. 


CS1 
1 
~ 


RIW 
I 
~ 


Os 
\ 
r- 
~ 
ADo-AD7 
VALID 
( READ DATA )-- 


Figure 18. Read Cycle Timing 


Interrupt Acknowledge Cycle. When one of 
the IP bits in the Z-CIO goes High and inter- 
rupts are enabled, the Z-CIO pulls its INT 
output line Low, requesting an interrupt. The 
CPU responds with an Interrupt Acknowledge 
cycle. When INTACK goes Low with IP set, the 
Z-CIO pulls its Interrupt Enable Out (lEO) 


Write Cycle. The CPU places an address on 
the address/data bus. The more significant bits 
and status information are combined and 
decoded by external'logic to provide two Chip 
Selects (CSa and CSd. Six bits of the least 
significant byte of the address are latched 
within the Z-CIO and used to specify a Z-CIO 
register. The CPU places the data on the 
address/data,bus and strobes it into the Z-CIO 
register by issuing a Data Strobe (DS). 


CS1 
I 
~ 


RlW 
\ 
c= 


Os 
\ 
r- 
ADAD~ 
0- 
7 
VALID 
WRITE DATA x= 


Figure 19. Write Cycle Timing 


Low, disabling all lower priority devices on the 
daisy chain. The CPU reads the Z-CIO inter- 
rupt vector by issuing a Low DS, thereby 
strobing the interrupt vector onto the address/ 
data bus. The IUS that corresponds to the IP is 
also set, which causes lEO to remain Low. 


INT ______________________ 1 


lEI 


lEO 
\--------------- 


\'--_---J/ 


ADo-AD7 


, °INTACK is decoded from 28000 status. 


Figure 20. Interrupt Acknowledge Timing 


( 


2014·016,017,018 


Absolute 
Maximum 
Ratings 


Standard 
Test 
Conditions 


DC 
Charac- 
teristics 


Capacitance 


8085·0209, 0001 


Voltages on all inputs and outputs 
with respect to GND .......... -0.3 V to + 7.0 V 
Operating Ambient 
Temperature ................. As Specified in 
Ordering Information 
Storage Temperature ........ -65°C to + 150°C 


The characteristics below apply for the 
follOWing standard test conditions, unless 
otherwise noted. All voltages are referenced to 
GND. Positive current flows -into the refer- 
enced pin. Standard conditions are as follows: 


+5V 


Figure 21. . Standard Test Load 


Symbol 
Parameter 
Min 


VIH 
Input High Voltage 
2.0 


VIL 
Input Low Voltage 
-0.3 


VOH 
Output High Voltage 
2.4 


VOL 
Output Low Voltage 


ILL 
Input Leakage 


IOL 
Output Leakage 
Icc 
Vee Supply Current 


Stresses greater than those listed under Absolute Maxi- 


mum Ratings may cause permanent damage to the device. 
This is a stress rating only; operation of the device at any 
condition above those indicated in the operational sections 
of these speCifications is not implied. Exposure to absolute 
maximum rating conditions for extended periods may affect 
device reliability. 


• +4;75 V ::s; Vee ::s; +5.25 V 
• GND = 0 V 


II TA as speCified in Ordering Information 
All ac parameters assume a load capacitance 
of 50 pF max. 


FROM OUTPUT 
UNDER TEST 


+5V d 


2.2K 


50 PFr 


Figure 22. Open-Drain Test Load 


Max 


Vee+ 0.3 


0.8 


0.4 


0.5 


± 10.0 


± 10.0 


200 


Unit 


V 


V 


V 


V 


V 
pA 


p,A 


rnA 


Condition 


IOH = -250 p,A 


IOL = +2.0 rnA 


IOL = +3.2 rnA 
0.4 :S VIN:s + 2.4 V 
O.4:sVOUT :S +2.4V 


Vee= 5 V ± 5% unless otherwise specified, over speCified temperature range. 


Symbol 
Parameter 
Min 
Max 
Unit 
Test Condition 


CIN 
Input Capacitance 
10 
pF 
U nrneasured Pins 


COUT 
Output Capacitance 
15 
pF 
Returned to Ground 
Cvo 
Bidirectional Capacitance 
20 
pF 


f = 1 MHz, over speCified temperature range. 
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CPU 
Interface 
Timing 


Interrupt 
Timing 


Interrupt 
Acknowledge 
Timing 
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INPUT(S) 
PATTERN MATCHES 
PAT'TEM ~TCH =1 


BIT PORT 
:.==========:-=@n-;:::::::::: • ..7,--------- 


ACKIN 
NOTE4 


COUNTER 
INPUT 


PCLK 


lEI 


lEO 


2014-019, 020, 021 


\ 


4MHz 
6 MHz 
No. 
Symbol 
Parameter 
Min 
Max 
Min 
Max 
Notes*t 


TwAS 
AS Low Width 
70 
2000 
50 
2000 


2 
TsA(AS) 
Address to AS I Setup Time 
30 
10 


3 
ThA(AS) 
Address to AS I Hold Time 
50 
30 


4-TsA(DS) 
Address to DS , Setup Time 
130 
100 
1- 


5 
TsCSO(AS) 
CSo to AS I Setup Time 
0 
0 


6 
ThCSO(AS) 
CSo to AS I Hold Time 
60 
40 


7 
TdAS(DS) 
AS t to DS 1 Delay 
60 
40 
S-TsCSl(DS)-- CS1 to DS 1 Setup Time 
100 
SO 


9 
TsRWR(DS) 
R/W (Read) to DS 1 Setup Time 
100 
SO 


10 
TsRWW(DS) 
R/W (Write) to DS 1 Setup Time 
a 
0 


11 
TwDS 
DS Low Width 
390 
250 


12-TsDW(DSf)--Write Data to DS I' Setup Time 
30 
20 


13 
TdDS(DRV) 
DS (Read) 1 to Address Data Bus Driven 
a 
0 
Bel 
14 
TdDSf(DR) 
DS I to Read Data Valid Delay 
250 
ISO 
C 


15 
ThDW(DS) 
Write Data to DS I Hold Time 
30 
20 
W 
en 


16- TdDSr(DR) -- DS I to Read Data Not Valid Delay 
0 
0 
~ 
17 
TdDS(DRz) 
DS I to Read Data Float Delay 
70 
45 
2 
... 
IS 
ThRW(DS) 
R/W to DS I Hold Tirpe 
55 
40 
0 


19 
ThCSl(DS) 
CS1 to DS I Hold Time 
55 
40 
20-TdDS(AS)--DS t to AS I Delay 
50 
25 


21 
Trc 
Valid Access Recovery Time 
1000 
650 
3 


22 
TdPM(INT) 
Pattern Match to INT Delay (Bit Port) 
1 +SOO 
1 +SOO 
6 


23 
TdACK(INT) 
ACKIN to INT Delay (Port with Handshake) 
4+600 
4+600 
4,6 
24-TdCI(INT)--Counter Input to INT Delay (Counter Mode) 
1 +700 
1+700---6- 


25 
TdPC(lNT) 
PCLK to INT Delay (Timer Mode) 
1 +700 
1 +700 
6 
26 
TdAS(lNT) 
AS to INT Delay 
300 


27 
TslA(AS) 
lNTACK to AS I Setup Time 
a 
a 


2S 
ThlA(AS) 
INTACK to AS t Hold Time 
250 
250 


29 
TsAS(DSA) 
AS I to DS (Acknowledge) I Setup Time 
350 
250 
5 


30-TdDSA(DR)--DS (Acknowledge) I to Read Data Valid Delay 
250 
180 


31 
TwDSA 
DS (Acknowledge) Low Width 
390 
250 


32 
TdAS(IEO) 
AS t to IEO I Delay (lNTACK Cycle) 
350 
250 
5 
33-TdIEI(IEO) --IEI to IEO Delay 
150 
100 
5- 


34 
TslEI(DSA) 
lEO to DS (Acknowledge) I Setup Time 
100 
70 
5 


35 
ThIEl(DSA) 
lEI to DS (Acknowledge) I Hold Time 
100 
70 


36 
TdDSA(lNT) 
DS (Acknowledge) 1 to INT I Delay 
600 
600 


NOTES: 
1. Parameter does not apply to Interrupt Acknowledge tran- 
S. The parameters for the devices in any particular daisy 
sactions. 
chain must meet the following constraint: the delay from 
2. Float delay is measured to the time when the output has 
AS r to f5S j must be greater than the sum of TdAS(lEO) 
changed 0.5 V from steady state with minimum ac load and 
for the highest priority peripheral. TsIEI(DSA) for the 
maximum dc load. 
lowest priority peripheral, and TdIEI(IEO) for each 
3. This is the delay from iSS, r of one CIO access to OS j of 
peripheral separating them in the chain. 
another CIO access. 
6. Units equal to AS cycle + ns. 
4. The delay is from DAV j for 3-Wire Input Handshake. The 
• Timings are preliminary and subject to change. 
delay is from DAC r for 3-Wire Output Handshake. One 
t Units in nanoseconds(nsl. except as noted. 
additional AS cycle is required for ports in the Single Buf- 
fere'd mode: 
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Strobed 
Handshake 


Interlocked 
Handshake 


a-Wire 
Handshake 
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INPUT 


OUTPUT 


OU'rPUT 


INPUT 


OUTPUT 


DATA ==x 
~ATAVALID 
X\..-__ 
_ 


0i=\ !:J- 
oe:: ----:...FF:l-3-it:b:}.....--' 
.....:..... __ 


DATA 


ACKiii 


DAY 


DATA 


DAY 
INPUT 


RFD 


OUTPUT 


DAC 
OUTPUT 


DATA 


DAC 
INPUT 


RFD 


INPUT 


DAY 


OUTPUT 


2014-022, 023, 024 


4MHz 
6 MHz 
No. 
Symbol 
Parameter 
Min 
Max 
Min 
Max 
Notes*t 


1 
TsDI(ACK) 
Data Input to ACKIN I Setup Time 
0 


2 
ThDI(ACK) 
Data Input to ACKIN I Hold Time - Strobed 
500 


Handshake 
3 
TdACKf(RFD) 
ACKIN I to RFD I Delay 
0 


4-TwACKl---ACKIN Low Width - Strobed Handshake 
250 


5 
TwACKh 
ACKIN High Width - Strobed Handshake 
250 


6 
TdRFDr(ACK) 
RFD I to ACKIN ,I Delqy 
0 
·7 
TsDO(DAV) 
Data Out to DA V I Setup Time 
25' 


8 
TdDAVf(ACK) 
DA V I to ACKIN I Delay 
0 


9-ThDO(ACK)-- Data Out to ACKIN I Hold Time -------- 


10 
TdACK(DAV) 
ACKIN I to DAV I Delay 
1 
11 
ThDI(RFD) 
Data Input to RFD I Hold Time - Interlocked 
0 


Handshake 


o 


o 


o 
20 
o 


1 
o 


12 
TdRFDf(ACK) 
RFD I to ACKIN I Delay - Interlocked Handshake 
0 
0 


-------2- 


2 


13-TdACKr(RFD)-ACKIN I (DAV I) to RFD I Delay - Interlocked--O------O-------- 
and 3-Wire Handshake 
14 
TdDAVr(ACK) 
DAV I to ACKIN I (RFD I ) - Interlocked and 
0 
o 
3-Wire Handshake 


15 
TdACK(DAV) 
ACKIN I (RFD I )to DAV I Delay - Interlocked and 
0 
o 
3-Wire Handshake 
16-TdDAVIf(DAC)-DAV I to DAC I Delay - Input 3-Wire Handshake--O------O-------- 


17 
ThDI(DAC) 
Data Input to DAC I Hold Time - 3-Wire 
0 
0 


Handshake 


18 
TdDACOr(DAV) DAC I to DAV I Delay - Input 3-Wire Handshake 
0 
0 


19 
TdDAVIr(DAC) DAV I to DAC I Delay - Input 3-Wire Handshake 
0 
0 
20-TdDAVOf(DAC)-DAV I to DAC I Delay - Output 3-Wire Handshake -0------ 0 -------- 


21 
ThDO(DAC) 
Data Output to DAC I Hold Time - 3-Wire 
1 
2 
Handshake 
22 
TdDACIr(DAV) DAC I to DAV I Delay - Output 3-Wire Handshake 
1 
1 
o 


2 
23 
TdDAVOr(DAC) DAV I to DAC I Delay - Output 3-Wire Handshake 
0 


NOTES: 
1. This time can be extended through the use of the d8skew 


timers. 
2. Units equal to AS cycle. 


• Timings are preliminary and subject to change. All timing 
references assume 2.0 V for a logic "1" and 0.8 V for a logic "0". 
r Units in nanoseconds (ns), except as noted. 
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Counter/ 
Timer 
Timing 
PCLK 


PCLKI2 


INTERNAL 


COUNTER 
INPUT 


TRIGGER 
INPUT 


GATE 
INPUT 


COUNTER 
OUTPUT 


_____ 
.J 


4MHz 
6 MHz 
No. 
Symbol 
Parameter 
Min 
Max 
Min 
Max 
Notes*t 


1 
TePC 
PCLK Cycle Time 
2S0 
4000 
165 
4000 


2 
TwPCh 
PCLK High Width 
105 
2000 
70 
2000 


3 
TwPCl 
PCLK Low Width 
105 
2000 
70 
2000 


4 
TfPC 
PCLK Fall Time 
20 
10 


5 
TrPC 
PCLK Rise Time 
20 
15 
6-TeCI 
Counter Input Cycle Time 
500 
330 


7 
TCIh 
Counter Input High Width 
230 
150 


8 
TwCIl 
Counter Input Low Width 
230 
150 


9 
TfCI 
Counter Input Fall Time 
20 
15 


10 
TrCI 
Counter Input Rise Time 
20 
15 
Il-TsTI(PC)---Trigger Input to PCLK 1 Setup Time--lS0 --------------- 
(Timer Mode) 


12 
TsTI(CI) 
Trigger Input to Counter Input 1 Setup 
150 


Time (Counter Mode) 
13 
TwTI 
Trigger Input Pulse Vlidth (High or Low) 200 


14 -TsGI(PC)---Gate Input to PCLK 1 Setup Time ---' 100 --------------- 


IS 
TsGI(CI) 


16 
ThGI(PC) 


(Timer Mode) 
Gate Input to Counter Input 1 Setup 
100 


Time (Counter Mode) 
Gate Input to PCLK 1 Hold Time (Timer 
100 


Mode) 


17 - 
ThGI(CI)---Gate Input to Counter Input 1 Hold --100 --------------- 
Time (Counter Mode) 
18 
TdPC(CO) 
PCLK to Counter Output Delay (Timer 
475 


19 
TdCI(CO) 


NOTES: 


Mode) 
Counter Input to Counter Output Delay 
(Counter Mode) 
475 


are valid for the next counter/timer cycle. 


2 


2 


2 


2 


2 


2 


1. PCLK is only used with the counter/timers (in Timer mode), the 
deskew timers, and the REQUESTIW AIT logic. If these func- 
tions are not used, the PCLK input can be held low. 


• Timings are preliminary and subject to change. All timing refer- 
ences assume 2.0 V for a logic "I" and 0.8 V for a logic "0". 


2. These parameters must be met to guarantee that trigger or gate 
t Units in nanoseconds (ns). 
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REQUEST/ 
WAIT 
Timing 


No. 
Symbol 


TdDS(REQ) 


2 
TdDS(WAIT) 


3 
TdPC(REQ) 


4 
TdPC(WAIT) 


5 
TdACK(REQ) 


Parameter 


PCLK 


ACKIN 
NOTE 1 


REQ 


TIS I to REQ I Delay 


TISI to WAIT I Delay 


PCLK I to REQ t Delay 


PCLK I to WAIT t Delay 


ACKIN I to REQ t Delay 


6 
TdACK(WAIT) 
ACKIN I to WAIT t Delay 


NOTES: 
I. The Delay is from DAV J for the 3-Wire Input Handshake. The 
delay is from DAC 1 for the 3-Wire Output Handshake. 
2. UnIts equal to AS cycles + PCLK cycles + ns. 


4MHz 
6MHz 
Min 
Max 
Min 
Max 


500 
500 
300 
300 
3+2 
+ 1000 
10 +600 


3. Units equal to PCLK cycles + ns . 
• Timings are preliminary and subject to change. All timing refer" 


ences assume 2.0 V for a logic "I" and 0.8 V for a l'ogic "0". 


t Units in nanoseconds (ns), except as noted. 


Reset 
Timing 
_DASSJ~ 
f~ 
',--------,. r~ 


RESET 
INTERNAL ----------------------~;- 


4 MHz 
6 MHz 
No. 
Symbol 
Parameter 
Min 
Max 
Min 
Max 


TdDSQ(AS) 
Delay from DS t to AS I for No Reset 
40 
15 
2 
TdASQ(DS) 
Delay from AS t to DS I for No Reset 
50 
30 


3 
TwRES 
Minimum Width of AS and DS both Low ·for Reset 
250 
170 


NOTES: 
1. Internal circutry allows for the reset proVided by the Z8 (DS 
held Low whJle AS pulses) to be sufficient. 


2014-026, 027 


• Timings are prehminary and subject to change. All timing refer- 
ences assume 2.0 V for a logic "1" and 0.8 V for a logic "0". 


t Units in nanoseconds (ns). 


Notes*t a 
0 w 
eft 
J: ... 
0 


1,2 


3 


Notes*t 
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Miscellaneous 
Port 
Timing 


No. 
Symbol 


Trl 


2 
TfI 
3 
Twl's 


4 
TwPM 


5 
TsPMD 


6 
. ThPMD 


NOTES: 


ANY INPUT 


1'. CATCHER 


INPUT 


PATTERN 
MATCH 


0-r =iL 


------~ 
~~---------------- 
________ I 
\_~ __________ _ 


INPUTeS) --------- 1'-------'1 -~------- 


DATATOBE ------~ ~---------~ ,----------- 


LATCHED TO 


PATTERN MATCH ------- I'----------J\ ~--------- 


4 MHz 
6 MHz 
Parameter· 
Min 
Max 


Any Input Rise Time 
Any Input Fall Time 
l's Catcher High Width 
250 


Pattern Match Input Valid (Bit Port) 
750 


Data Latched on Pattern Match Setup Time (Bit Port) 
a 
Data Latched on Pattern Match Hold Time (Bit Port) 
1000 


100 
100 


Min 
Max 


170 


500 


a 


650 


100 


100 


Notes*t 


1. If the input Is programmed inverting, a Low·going pulse of the 
same width will be detected. 


• Timings are preliminary and subject to change. All timing refer- 


ences assume 2.0 V for a logic "1" and 0.8 V for a logic "0", 


Bidirectional 
Port 
Timing 


INIOUT 


RFD/DAV 


DATA 


INIOUT 


RFD/DAV 


/ 


I 
-0-- 


J 


. 


1;1 


t Units in nanoseconds (ns). 


.J., 


CD 
., 


CD 
i 
CD 
't 


DATA _______________ __ 


No. 
Symbol 
Parameter 


TdIOr(DAV) 
110 I to RFD/DA V High Delay 


2 
TdIOr(DRZ) 
110 I to Data Float Delay 
3 
TdIOr(ACK) 
I/O I to ACKIN I Delay 


4 
TdIOf(RFD) 
I/O I to RFD/DAV High Delay 


5 
TdIOf(DAV) 
110 I to RFD/DAV I Delay 


6 
TdDO(IO) 
I/O I to Data Bus Driven 


NOTES: 
I. Units equal to AS cycle~ 
_. 


2. Minimum delay is four AS cycles or one AS cycle after the cor- 


responding IP is cleared, whichever is longer. 
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4MHz 
6 MHz 
Min 
Max 
Min 
Max 
Notes*t 


500 
500 


500 
500 


2 


500 
500 


3 
3 


2 
2 


• Timings are preliminary and subjecHo change. All timing 
references assume 2.0 V for a logic "I" and 0.8 V for a logic "0". 


t Units in nanoseconds (ns). 


2014'028 
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Ordering 
Product 
Package/ 
Product 
Package/ 
Information 
Number 
Temp 
Speed 
Description 
Number 
Temp 
Speed 
Description 


28036 
CE 
4.0 MHz 
2-CIO (40-pin) 
28036A 
CE 
6.0 MHz 
2-CIO (40-pin) 


28036 
CM 
4.0 MHz 
Same as above 
28036A 
CM 
6.0 MHz 
Same as above 


28036 
CMB 
4.0 MHz 
Same as above 
28036A 
CMB 
6.0 MHz 
Same as above 


28036 
CS 
4.0 MHz 
Same as above 
28036A 
CS 
6.0 MHz 
Same as above 


28036 
DE 
4.0 MHz 
Same as above 
28036A 
DE 
6.0 MHz 
Same as above 


28036 
DS 
4.0 MHz 
Same as above 
28036A 
DS 
6.0 MHz 
Same as above 


28036 
PE 
4.0 MHz 
Same as above 
28036A 
PE 
6.0 MHz 
Same as above 


28036 
PS 
4.0 MHz 
Same as above 
28036A 
PS 
6.0 MHz 
Same as above 


NOTES: C = Ceramic, D = Cerdip, P = Plastic; E = -40°C to +85°C, MB = -55°C to 125°C with MIL-STD-883 with Class B processing, 
S = O°C to +70°C. 


00-2014-02 
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Features 


General 
Description 


2020-096, 097 


[J 128-byte FIFO buffer provides asynchronous 
bidirectional CPU/CPU or CPU/peripheral 
interface, expandable to any width in byte 
increments by use of multiple FIOs. 


[J Interlocked 2-Wire or 3-Wire Handshake 
logic port mode; Z-BUS or hon-Z-BUS 
interface. 


[J Pattern-recognition logic stops DMA 
transfers and/or interrupts CPU; preset byte 
count can initiate variable-length DMA 
transfers. 


The Z8038 FlO provides an asynchronous 
128-byte FIFO buffer between two CPUs or 
between a CPU and a peripheral device. This 
buffer interface expands to a 16-bit or wider 
data path and expands in depth to add as 
many Z8060 FIFOs (and an additional FlO) as 
are needed. 
The FlO manages data transfers by assuming 


Z-BUS, non-Z-BUS microprocessor (a general- 
ized microprocessor interface), Interlocked 


{ 
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I 
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- 
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BUS 
- 
03 PORT I PORT 03 
BUS 


- 
O2 
1 
I 
2 
02 
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_Do 
I 
00 
- 


CONT.J ~! z.1.. ! ~) 
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l-~ FI,O 
~ 
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-0 
0- 


CONFIGURATION { - 
Ml 
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+5V 
GND 


Figure 1. Pin Functions 


18038 Z8000™ 
Z-FIO FIFO Inputl 


ClU1Rpu~ ~iiRei'fa(Ce Uoii 


Product 
Specification 


September 1983 


II Seven sources of vectoredlnonvectored 
interrupt which include pattern-match, 
byte count, empty or full buffer status; 
a dedicated "mailbox" register with 
interrupt capability provides CPU/CPU 
communication. 


I:'l REQUEST/WAIT lines control high-speed 
data transfers. 


m All functions are software controlled via 
directly addressable read/write registers. 


2-Wire Handshake, and 3-Wire Handshake 
operating modes. These modes interface 
dissimilar CPUs or CPUs and peripherals 
running under differing speeds or protocols, 
allowing asynchronous data transactions and 
improving I/O overhead by as much as two 
orders of magnitude. Figures 1 and 2 show 
how the signals controlling these operating 
modes are mapped to the FlO pins. 


I 
+5V 


I 
I 
37 
I 
5 
36 


6 PORT: PORT35 
7 
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34 
8 SIDE I SIDE 33 


I 


10 
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13 
I 


14 
I 
02 


15 
I 
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16 
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I 
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Figure 2. Pin Assignments 
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General 
Description 
(Continued) 


Functional 
Description 
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The FlO supports the Z-BUS interrupt pro- 
tocols, generating seven sources of interrupts 
upon any of the following events: a write to a 
message register, change in data direction, 
pattern match, status match, over/underflow 
error, buffer full and buffer empty status. Each 
interrupt source can be enabled or disabled, 
and can also place an interrupt vector on the 
port address/data lines. 
The data transfer logic of the FlO has been 


CPU 
INTERFACE 


specially designed to work with DMA (Direct 
Memory Access) devices for high-speed 
transfers. It provides for data transfers to or 
from memory each machine cycle, while the 
DMA device generates memory address and 
control signals. The FlO also supports the 
variably sized block length, improving system 
throughput when multiple variable length 
messages are transferred amongst several 
sources. 


CPU 
INTERFACE 
OR 
I/O PORT 


DATA 


BUS \r--,f---t 


128 X 8 


FIFO BUFFER 
DATA 
r--""\.--" BUS 


PORT 1 SIDE : PORT 2 SIDE 


Figure 3. FlO Block Diagram 


Operating Modes. Ports 1 and'2 operate in 
any of twelve combinations of operating 
modes, listed in Table 2. Port 1 functions in 
either the Z-BUS or non-Z-BUS microprocessor 
modes, ... ;hile Port 2 functions in Z-BUS, non- 
Z-BUS, Interlocked 2-Wire Handshake, and 
3-Wire Handshake modes. Table 1 describes 
the signals and their corresponding pins in 
each of these modes. 


Signal 
Z-BUS 
Z-BUS 
Pins 
Low Byte 
High Byte 


[KJ 
REQIWT 
REQIWT 
[!] 
DMASTB 
DMASTB 
@J 
DS 
DS 
[Q] 
R!W 
PJW 
~ 
CS 
CS 
[TI 
AS 
AS 
@] 
INTACK 
Aa 


[ill 
lEO 
Al 


OJ 
lEI 
A2 


W 
INT 
A3 


*2 side only. 


The pin diagrams of the FlO are identical, 
except for two pins on the Port 1 side, which 
select that port's operating mode. Port 2's 
operating mode is programmed by two bits in 
Port l's Control register O. Table 2 describes 
the combinations of operating modes; Table 3 
describes the control signals mapped to pins 
A-J in the five possible operating modes. 


Interlocked 
3-Wire 


Non-Z-BUS 
HS Port'" 
HS Port'" 


REQIWT 
RFD/DAV 
RFD/DAV 


DACK 
ACKIN 
DAV/DAC 


RD 
FULL 
DAC/RFD 


WR 
EMPTY 
EMPTY 


CE 
CLEAR 
CLEAR 


C/D 
DATA DIR 
DATA DIR 


INTACK 
INa 
INa 


lEO 
OUTI 
OUTI 


lEI 
OE 
OE 


INT 
OUT3 
OUT3 


Table 1. Pin Assignments 


2020·001 


Functional 
Description 
( Continued) 


2020-002. 003 


Z8002 


SYSTEM 
MEMORY 


Modo 
MI 
MO 
BI 
BO 
Port I 
Port 2 


0 
0 
0 
0 
0 
Z-BUS Low Byte 
Z-BUS Low Byte 


0 
0 
0 
Z-BUS Low Byte 
Non-Z-BUS 


2 
0 
0 
0 
Z-BUS Low Byte 
3-Wire Handshake 
3 
0 
0 
Z-BUS Low Byte 
2-Wire Handshake 


4 
0 
0 
0 
Z-BUS High Byte 
Z-BUS High Byte 


5 
0 
0 
1 
Z-BUS High Byte 
Non-Z-BUS 


6 
0 
0 
Z-BUS High Byte 
3-Wire Handshake 


7 
0 
Z-BUS High Byte 
2-Wire Handshake 


8 
0 
0 
0 
Non-Z-BUS 
Z-BUS Low Byte 


9 
0 
0 
1 
Non-Z-BUS 
Non-Z-BUS 


10 
0 
0 
Non-Z-BUS 
3-Wire Handshake 


11 
0 
Non-Z-BUS 
2-Wire Handshake 


Tablo 2. Operating Modes 


Z·BUS 


Z·FIO 


Z·BUS 
Z80 BUS 


Figuro 4. CPU to CPU Configuration 


[] 


SYSTEM 
MEMORY 


CHANNEL A 


CHANNEL B 


PORT 2 
<8> 


PORT 3 
<8> 


Z80 BUS 


110 


Z80 


} 
HANDSHAKE 
_ 
SIGNALS 


MEMORY 


Figure 5. CPU to 1/0 Configuration 
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N 
CQ e 
W 
00 
N • 
DIJ ... o 


Pins Common 
Pin 
Pin 
Pin 
Signal 
To Both Sides 
Signals 
Names 
Numbers 
Description 


MO 
MO 
21 
M 1 and MO program Port 1 
Ml 
M1 
19 
side CPU interface 


+5 Vdc 
+5 Vdc 
40 
DC power source 
GND 
GND 
20 
DC power ground 


Z-BUS 
Pin Numbers 
Low Byte 
Pin 
Pin 
Port 
Signal 
Mode 
Signals 
Names 
2 
Description 


ADO-AD7 
DO-D7 
11-18 
29-22 
Multiplexed bidirectional address/data lines, Z-BUS 


(Address/Data) 
compatible. 


REQ/WAIT 
A 
39 
Output, active Low, REQUEST (ready) line for DMA 
(RequestIW ait) 
transfer; WAIT line (open-drain) output for syn- 
chronized CPU and FlO data transfers. 


DMASTB 
B 
2 
38 
Input, active Low. Strobes DMA data to and from 
(Direct Memory 
the FIFO buffer. 
Access Strobe) 


DS 
C 
3 
37 
Input, active Low. Provides timing for data trans- 
(Data Strobe) 
fer to or from FlO. 


R/W 
D 
4 
36 
Input; active High signals CPU read from FlO; 


(Read/W rite) 
active Low signals CPU write to FlO. 


CS 
E 
5 
35 
Input, active Low. Enables FlO. Latched on the 
(Chip Select) 
rising edge of AS. 


AS 
F 
6 
34 
Input, active Low. Addresses, CS and INTACK 
(Address Strobe) 
sampled while AS Low. 


INTACK 
G 
7 
33 
Input, active Low. Acknowled~ an interrupt. 
(Interrupt 
Latched on the rising edge of AS. 


Acknowledge) 


lEO 
H 
8 
32 
Output, active High. Sends interrupt enable to 
(Interrupt 
lower priority device lEI pin. 
Enable Out) 


lEI 
9 
31 
Input, active High. Receives interrupt enable from 
(Interrupt 
higher priority device lEO signal. 
Enable In) 


INT 
10 
30 
Output, open drain, active Low. Signals FlO inter- 
(Interrupt) 
rupt request to CPU. 


Z-BUS 
Pin Numbers 
High Byte 
Pin 
Pin 
Port 
Signal 
Mode 
Signals 
Names 
2 
Description 


ADO-AD7 
Do-D7 
11-18 
29-22 
Multiplexed bidirectional address/data lines, Z-BUS 


(l\.ddress/Data) 
compatible. 


REQ/WAIT 
A 
39 
Output, active Low, REOUEST (ready) line for DMA 
(RequestlWait) 
transfer; WAIT line (open-drain) output for syn- 
chronized CPU and FlO data transfers. 


DMASTB 
B 
2 
38 
Input, active Low. Strobes DMA data to and from the 


(Direct Memory 
FIFO buffer. 
Access Strobe) 


DS 
C 
3 
37 
Input, active Low. Provides timing for transfer of data 
(Data Strobe) 
to or from FlO. 


RIW 
D 
4 
36 
Input, active High. Signals CPU read from FlO; active 
(Read/Write) 
Low signals CPU write to FlO. 


CS 
E 
5 
35 
Input, active Low. Enables FlO. Latched on the 
(Chip Select) 
rising edge of AS. 


AS 
F 
6 
34 
Input, active Lo~ Addresses, CS and INT ACK are 
(Address Strobe) 
sampled while AS is Low. 


AO 
G 
7 
33 
Input, active High. With AI, A2, and A3, addresses 
(Address Bit 0) 
FlO internal registers. 


Al 
H 
8 
32 
Input, active High. With AO, A2, and A3, addresses 
(Address Bit 1) 
FlO internal registers. 


A2 
9 
31 
Input, active High. With AO' AI, and A3, addresses 
(Address B,it 2) 
FlO internal registers. 


A3 
10 
30 
Input, active High. With AO' AI, and A2, addresses 
(Address Bit 3) 
FlO internal registers. 


Table 3. Signal/Pin Descriptions 
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Non-Z-BUS 
Pin Numbers 
Mode 
Pin 
Pin 
Port 
Signal 


Signals 
Names 
4 
Description 


DO-D7 
DO-D7 
11-18 
29-22 
Bidirectional data bus. 
(Data) 


REQIWT 
A 
39 
Output. active Low. REQUEST (ready) line for DMA 
(RequestlWait) 
transfer; WAIT line (open-drain) output for syn- 
chronized CPU and FlO data transfer. 


DACK 
B 
2 
38 
Input. active Low. DMA acknowledge. 
(DMA Acknowledge) 


RD 
C 
3 
37 
Input. active Low. Signals CPU read from FlO. 


(Read) 


WR 
D 
4 
36 
Input. active Low. Signals CPU write to FlO. 


(Write) 


CE 
E 
5 
35 
Input. active Low. Used to select FlO. 


(Chip Select) 
c/15 
F 
6 
34 
Input. active High. Identifies control byte on DO-D7; 


(ControVData) 
active Low identifies data byte on DO-D7. 


INTACK 
G 
7 
33 
Input. active Low. Acknowledges an interrupt. 
N 
(Interrupt 
00 
Acknowledge) 
0 
lEO· 
H 
8· 
32 
Output. active High. Sends interrupt enable to 
W 


(Interrupt 
lower priority device lEI pin. 
00 


Enable Out) 
N • 


lEI 
9 
31 
Input. active High. Receives interrupt enable from 
-:I 
.... 


(Interrupt 
higher priority device lEO signal. 
0 


Enable In) 


INT 
10 
30 
Output, open drain. active Low. Signals FlO interrupt 
(Interrupt) 
to CPU. 


Port 2-1/0 
Pin 
Pin 
Pin 
Signal 
Port Mode 
Signals 
Names 
Numbers 
Mode 
Description 


DO-D7 
DO-D7 
29-22 
2-Wire HS" 
Bidirectional data bus. 
(Data) 
3-Wire HS 


RFD/DAV 
A 
39 
'2-Wire HS 
Output. RFD active High2!gnals peripherals that FlO 


(Ready for Data/Data 
3-Wire HS 
is ready to receive data. DA V active Low 'signals 
Available) 
that FlO is ready to send data to peripherals. 


ACKIN 
B 
38 
2-Wire HS 
Input. active Low. Signals FlO that output data is 
(Acknowledge Input) 
received by peripherals or that input data is valid. 


DAV/DAC 
B 
38 
3-Wire HS 
Input; DAV (active Low) signals that data is valid on 
(Data Available/Data 
bus. DAC (active High) signals that output data is 
Accepted) 
accepted by peripherals. 


FULL 
C 
37 
2-Wire HS 
Output. open drain. active High. Signals that FlO 
buffer is full. 


DAC/RFD 
C 
37 
3-Wire HS 
Direction controlled by internal programming. Both 
(Data Accepted/Ready 
active High. DAC (an output) signals that FlO has 
for Data) 
received data from peripheral; RFD (an input) signals 
that the listeners are ready for data. 


EMPTY 
D 
36 
2-Wire HS 
Output. open drain. active High. Signals that FIFO 


3-Wire HS 
buffer is empty. 


CLEAR 
E 
35 
2-Wire HS 
Programmable input or output. active Low. Clears all 
3-WireHS 
data from FIFO buffer. 


DATA DIR 
F 
34 
2-Wire HS 
Programmable input or output. Active High signals 
(Data Direction) 
3-Wire HS 
data input to Port 2; Low signals data output from 
Port 2. 


INO 
G 
33 
2-Wire HS 
Input line to DO of Control Register 3. 
3-Wire HS 


OUTl 
H 
32 
2-Wire HS 
Output line from Dl of Control Register 3. 
3-Wire HS 


OE 
31 
2-Wire HS 
Input. active Low. When Low. enables bus drivers. 
(Output Enable) 
3-Wire HS 
Whim High. floats bus drivers at high impedance. 


OUT3 
30 
2-Wire HS 
Output line from D3 of Control register 3. 
3-Wire HS 


"Handshake 


Table 3. Signal/Pin Descriptions (Continued) 
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Reset 


CPU 
Interfaces 


340 


The FlO can be reset under either hardware 
or software control by one of the following 
methods: 


• By forcing both AS and DS Low simultane- 
ously in Z-BUS mode (normally illegal). 


• By forcing RD and WR Low Simultaneously 
in non-Z-BUS mode. 


• By writing a 1 to the Reset bit in Control 


register 0 for software reset. 


In the Reset state, all contl'ol bits are cleared 
to O. Only after clearing the Reset bit (by 


The FlO is designed to work with both 


Z-BUS- and non-Z-BUS-type CPUs on both Port 
1 and Port 2. The Z-BUS configuration inter- 
faces CPUs with time-multiplexed address and 
data information on the same pins. The Z8001, 
Z8002, and Z8 are examples of this type of 
CPU. The AS (Address Strobe) pin is used to 
latch the address and chip select information 
sent out by the CPU. The RlW (ReadlWrite) 
pin and the DS (Data Strobe) pin are used 
for timing reads and writes from the CPU to 


writing a 0 to it) can the other command bits 
be programmed. This action is true for both 
sides of the FlO when programmed as a CPU 
interface. 
For proper system control, when Port 1 is 
reset, Port 2 is also reset. In addition, all Port 
2's outputs are floating and all inputs are 
-ignored. To initiate the data transfer, Port 2 
must be enabled by Port 1. The Port 2 CPU 
can determine when it is enabled by reading 
Control register 0, which reads "floating" data 
bus if not enabled and "01 H" if enabled. 


the FlO (Figures 6 and 7). 
The non-Z-BUS configuration is used for 


CPUs where the address and data buses are 
separate. Examples of this type of CPU are the 
Z80 and 8080. The RD (Read) and WR (Write) 
pins are used to time reads and writes from the 
CPU to the FlO (Figures 9 and 10); The c/iS 
(Control/Data) pin is used to.directly access 
the FIFO buffer (C/I5 = 0) and to access the 
other registers (C/D = 1). Read and write to all 


ADO-AD7 --( A~~~rosS )>--------( 
TO CPU )>------ 


ruw=:/ 
\ ____ _ 


\I...... __ --J! 


Figure 6. Z-BUS Read Cycle Timing 


ADo-AD7 ----c( A~~~FosS H~· ___ 
D_A_TA_F_RO_M_C_PU __ -.J»)---- 
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V 
\J 


\ 


\~-_/ 


Figure 7. Z-BUS Writo Cycle Timing 
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CPU 
Interfaces 
( Continued) 


WAIT 
Operation 


Interrupt 
Operation 


2020-006, 007, 008 


registers except the FIFO bufferl are two-step 
operations, described as follows (Figure 8). 
First, write the address (c/iS = 1) of the register 
to be accessed into the Pointer Register (State 
0); second, read or write (C/D = 1) to the 
register pointed at previously (State 1). Con- 
tinuous status monitoring can be performed in 
State 1 by continuous Control· Read operations 
(C/D = 1). 


RD OR WR 


RESET = 0 


WRTO PTR 


(C/O = 1) 


(CtO = 0) 


1 The FIFO buffer can also be accessed by this two-step operation. 
Figure 8. Register Access in Non-Z-BUS Mode 


CID_...-JX ____________ >C: 


~----------------------------~( ro~ }-- 


\~ ____________ ~r_ 


\ _____ 
~I 


Figure 9. Non-Z-BUS Read Cycle Timing 


cm 
X 
X 


Do-D7 
< 


FROM CPU 
} 


CE 
\ 
I 


WR 
\ 
I 


Figure 10. Non-Z-BUS Write Cycle Timing 


When data is output by the CPU, the 
REQ/WT (WAIT) pin is active (Low) only when 
the FIFO buffer is full, the chip is selected, 
and the FIFO buffer is addressed. WAIT goes 
inactive when the FIFO buffer is not full. 


When data is input by the CPU, the 
REQ/WT pin becomes active (Low) only when 
the FIFO buffer is empty, the chip is selected, 
and the FIFO buffer is addressed. WAIT goes 
inactive when the FIFO buffer is not empty. 


The FlO supports Zilog's prioritized daisy 
chain interrupt protocol for both Z-BUS and 
non-Z-BUS operating modes (for more details 
refer to the Zilog Z-EUS Summary). 
Each side of the FlO has seven sources of 
interrupt. The priorities of these devices are 
fixed in the following order (highest to lowest): 
Mailbox Message, Change in Data Direction, 
Pattern Match, Status Match, Overflow/ 


Underflow Error, Buffer Full, and Buffer 
Empty. Each interrupt source has three bits 
that control how it generates the interrupt. 
These bits are Interrupt Pending (IP), 
Interrupt Enable (IE), and Interrupt Under 
Service (IUS). 


In addition, each side of the FlO has an 
interrupt vector and four bits controlling the 
FlO interrupt logic. These bits are Vector 
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Interrupt 
Operation 
(Continued) 


Includes Status (VIS), Master Interrupt Enable 
(MIE), Disable Lower Chain (DLC), and No 
Vector (NV). 
A typical Interrupt Acknowledge cycle for 


Z-BUS oPElration is shown in Figure 11 and for 
non-Z-BUS operation in Figure 12. The only 
difference is that in Z-BUS mode, INTACK is 
latched by AS, and in non-Z-BUS mode 
INTACK is not latched. 
When MIE = 1, reading the vector always 
includes status, independent of the state of the 


VIS bit. In this way, when VIS = 0, all infor- 
mation can be obtained with one additional 
read, thus conserving vector space. When 
MIE = 0, reading the vector register returns 
the unmodified base vector so that it can be 
verified. 
In non-Z-BUS mode, the IPs do not get set 
while in State 1. Therefore, to minimize inter- 
rupt latency, the FlO should be left in State O. 
In Z-BUS mode IPS are set by an AS following 
the event. 


ADO-AD7 ~~------« VECTOR »)---- 


\ _____ r- 


lEI 
/ 
__ 
...J 


INT 
/ 


--------------~ 


Figure 11. Z-BUS Interrupt Acknowledge Cycle 


DO-D7 ------------<~)---- 


\~ __ ---JI 


lEI 
/ 
___ 
.-oJ 


INT 
/ 
---------' 


Figure 12. Non-Z-BUS Interrupt Acknowledge Cycle 


CPU to CPU 
DMA Operation. The FlO is particularly well 
however, the CS (Chip Select) signal is not 
ignored and therefore must be kept invalid. 
Figures 13 and 14 show typical timing. 
Operation 
suited to work with a DMA in both Z-BUS and 
non-Z-BUS modes. A data transfer between the 
FlO and system memory can take place during 
every machine cycle on both sides of the FlO 
simultaneously. 
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In Z-BUS mode, the DMASTB pin (DMA 
Strobe) is used to read or write into the FIFO 
buffer. The R/W (Read/Write) and DS (Data 
Strobe) signals are ignored by the FlO; 


In Non-Z-BUS mode, the DACK pin (DMA 
Acknowledge) is used to tell the FlO that its 
DMA request is granted. After DACK goes 
Low, every read or write to the FlO goes into 
the FIFO buffer. Figures 15 and 16 show 
typical timing. 


2020-009,010 


CPU to CPU 
Operation 
( Continued) 


2020-011, 012, 013, 014 


AID BUS 
DATA FROM FlO TO MEMORY 


\\--__ 
--J1 


RlW 


\ ______ 1 


Figure 13. Z-BUS flO to Memory Data Transaction 


AID BUS 
DATA FROM MEMORY TO FlO 


DS 
\'--___ 
------', 


RlW 


DMASTB 
\ ___ 1 


Figure 14. Z-BUS Memory to flO Data Transaction 


ADDRESSES ===>< _____ 
M_E_M_O_RY_A_D_D_R_ES_S_O_F_W_R_IT_E ____ -J)(~ ____________________ __ 


D:~: --------C(DATA FROM FlO TO MEMORY}----(,, _____________ ---I>-- 


MEMORY 
WRITE 


110 


READ 


DACK ~~ 
__________________________________________________ __ 


Figure 15. Non-Z-BUS FlO to Memory Transaction 


ADDRESSES ===>< 
MEMORY ADDRESS OF READ 
x~ _______________________ _ 


DATA _______ ~( 
DATA FROM 
BUS 
MEMORY TO FlO »)--~(------I>- 


MEMORY~ 
/ 
READ 
\". __________ --J. 


\_-----1 


DACK ~~ 
__________ ~ 
_________________ ___ 


Figure 16. Non-Z-BUS Memory to FlO Data Transaction 
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Operation 
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The FlO provides a special mode to enhance 
its DMA transfer capability. When data is 
written into the FIFO buffer, the REQ/WT 
(REQUEST) pin is active (Low) until the FIFO 
buffer is full. It then goes inactive and stays 
inactive until the number of bytes in the FIFO 
buffer is equal to the value programmed into 
the Byte Count Comparison register. Then the 
REQUEST signal goes active and the sequence 
starts over again (Figure 17). 


REO 
(] 
ACTIVE .......;4~ .... --r--..... --"""0 


When data is read from the FlO, the 


REQIWT pin (REQUEST) is inactive until the 
number of bytes in the FIFO buffer is equal to 
the value programmed in the Byte Count Com- 
parison register. The REQUEST signal then 
goes active and stays active until the FIFO buf- 
fer is empty. When empty, REQUEST goes 
inactive and the sequence starts over again 
(Figure 18). 


ACTIVE --\----_1-----...-04- 


CD 
(] 
CD 
INACTIVE .....:::+---___ ----+=--.,---- 


FJLL 


CD 
CD 
INACTIVE ---::~--""""";"'-"'--.....J-.... NUMBER OF BYTES IN FIFO 


EMPTY 
FULL 


NUMBER IN BYTE COUNT COMPARISON REGISTER 


NOTES: 
1. FIFO empty. 
2. REQUEST enabled, FlO requests DMA transfer. 
3. DMA transfers data into the FlO. 
4. FIFO fun, REQUEST inactive. 
5. The FIFO empties from the opposite port until the number 
of bytes in the FIFO buffer is the same as the number pro- 
grammed in the Byte Count Comparison register. 


Figure 17. Byte Count Control: Write to flO 


Message Registers. Two CPUs can communi- 
cate through a dedicated "mailbox" register 
without involving the 128 X 8 bit FIFO buffer 
(Figure 19). This mailbox approach is useful 
for transferring control parameters between 
the interfacing devices on either side of the 
FlO without using the FIFO buffer. For 
example, when Port l's CPU writes to the 
Message Out register, Port 2's message IP is 
set. If interrupts are enabled, Port 2's CPU is 


EMPTY 


NUMBER IN BYTE COUNT COMPARISON REGISTER 


NOTES: 
1. FIFO empty. 
2. CPU/DMA fills FIFO buffer from the opposite port. 
3. Number of bytes in FIFO buffer is the same as the number 
of bytes programmed in the Byte Count Comparison register. 
4. REQUEST goes active. 
5. DMA transfers data out of FIFO until it is empty. 


Figure 18. Byte Count Control: Read from FlO 


interrupted. Port 2' s message IP status is 
readable from the Port 1 side. When Port 2's 
CPU reads the data from its Message In regis- 
ter, the Port 2 IP is cleared. Thus, Port l's 
CPU can read when the message has been 
read and can now send another message or 
follow whatever protocol that is set up between 
the two CPU's. The same transfer can also be 
made from Port 2' s CPU to Port l' s CPU. 


PORT 1 < 
MESSAGE OUT 
REGISTER 


REGISTER 
ADDRESS 
"C" 


..t! 
::.. 
TO 
PORT 2 


MESSAGE 
\ 
REGISTER 
vi 
PORT 1 


REGISTER 
ADDRESS 
"B" 


PORT 2 


MESSAGE IN 
REGISTER 


PO 
MESS 


REG 
- 


RT 1 
MESSAGE 
AGEIN 
REGISTER 
ISTER 
PORT 2 


TO 
REGISTER 
PORT 1 


ADDRESS 
"B" - 


NOTE: Usable only for CPU/CPU interface. 


Figure 19. Message Register Operation 
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Operation 
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CLEAR (Empty) FIFO Operation. The CLEAR 
FIFO bit (active Low) clears the FIFO buffer of 
data. Writing a 0 to this bit empties the FIFO 
buffer, inactivates the REQUEST line, and 
disables the handshake (if programmed). The 
CLEAR bit does not affect any control or data 
register. To remove the CLEAR state, write a 1 
to the CLEAR bit. 
In CPU/CPU mode, under program control, 
only one of the ports can empty the FIFO by 
writing to its Control Register 3, bit 6. The 
Port 1 CPU must program bit 7 in Control . 
Register 3 to determine which port controls the 
CLEAR FIFO operation (0 = Port 1 control; 
1 = Port 2 control). 
Direction of Data Transfer Operation. The 


Data Direction bit controls the direction of data 
transfer in the FIFO buffer. The Data Direction 
bit is defined as 0 = output from CPU and 
1 = input to CPU. This bit reads correctly 
when read by either port's CPU. For example, 
if Port l's CPU reads a 0 (CPU output) in its 
Data Direction bit, then Port 2's CPU reads a 1 
(input to CPU) in its Data Direction bit. 
In CPU/CPU mode, under program control, 
only one of the ports can control the direction 
of data transfer. The Port 1 CPU must program 
bit 5 in Control Register 3 to determine which 
port controls the data direction (0 = Port 1 
control; 1 = Port 2 control). Figure 20 shows 
FlO data transfer options. 


(PROGRAM REGISTERS FOR OPERATING MODE, 
PORT 2 CONFIGURATION, DATA TRANSFER CONTROL, ETC.) 


PORT 1 (CPU) 


EXCHANGE BYTES 
VIA MESSAGE REGISTER 


PORT 2 (CPU) 


(DMA OR INTERRUPT· 
DRIVEN TRANSFERS, AS 


TERMINATES ON ANY 
TERMINATES ON ANY 


OF THESE CONDITIONS: 
OF THESE CONDITIONS: 
·DMA BLOCK LENGTH REGISTER = 0 
·CPU COMPLETES BUFFER DUMP 
·FIO PATTERN MATCH INTERRUPT 
·FIO PATTERN MATCH INTERRUPT 
·BYTE COUNT DISABLES REO 
·FIO BYTE COUNT INTERRUPT 
I 
·FIO Full I Empty INTERRUPT 
I 
I 
l, 
....... ) 


........ 
.......- 
...... , 
.......-~ 
, 
.......- 
y 
I 


EXCHANGE BYTES 
VIA MESSAGE REGISTERS 
----------- 


FOR PORT 1) 


I 
I 
I 
t 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 


PORT 2 (110) 


TRANSFERS DATA BYTE· 
AT·A·TIME UNTIL 
FIFO BUFFER IS 
Full OR Empty 
\ 
/ Y 
t 
I 
I 


1 


1 
I 


1 
I 
I 
·1 
I 


1 


1 


1 


1 


CONTINUE OR REPROGRAM PORT REGISTERS WITH NEW BLOCKS OF CONTROL BYTES. 


Figure 20. flO Data Transfer Options 
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, When Port 2 is programmed in the Inter- 
locked 2-Wire Handshake mode or the 3-Wire 
Handshake mode, and Port A is programmed 
in 2-BUS or non-2-BUS Microprocessor mode, 
the FlO interfaces a CPU and a peripheral 
device. In the Interlocked 2-Wire Handshake 
mode, RFD/DA V and ACKIN strobe data to 
and from Port 2. In the 3-Wire Handshake 
mode, RFD/DAV, DA VlDAC, and DAC/RFD 
signals control data flow. 
Interlocked 2-Wire Handshake. In the Inter- 
locked Handshake, the action of the FlO must 
be acknowledged by the other half of the 
handshake before the next action can take 
place. In output mode, Port 2 does not indicate 
that new data is available until the external 
device indicates it is ready for the data. 
Similarly, in input mode, Port 2 does not indi~ 
cate that it is ready for new data until the data 
source indicates that the previous byte of the 
data is no longer available, therebyacknowl- 
edging Port 2's acceptance of the last byte. 
This allows the FlO to directly interface to a 
28's port, a CIO's port, a UPC's port, another 
FlO port, or another FIFO 28060, with no 
external logic (Figures 21 and 22). 


3-Wire Handshake. The 3-Wire Handshake is 
designed for applications in which one output 
port is communicating with many input ports 
simultaneously. It is essentially the same as the 
Interlocked Handshake, except that two signals 
are used to indicate that an input port is ready 
for new data or that it has accepted the present 
data. In the 3-Wire Handshake, the rising 
edge of the RFD status line indicates that the 
port is ready for data, and the rising edge of 
the DAC status line indicates that the data has 
been accepted. With 3-Wire Handshake, the 
lines of many input ports can be bussed 
together with open-drain drivers and the out- 


put port knows when all of the ports are ready 
and have accepted the data. This handshake is 
the same handshake used in the IEEE-488 
Instruments. Since the port's direction can be 
changed under software control, bidirectional 
IEEE-488-type transfers can be performed. 
Figures 23 and 24 show the timings associated 
with 3-Wire Handshake communications. 


CLEAR FIFO Operation. In CPU-to-I/O 
operation, the CLEAR FIFO operation can be 
performed by the CPU side (Port 1) under soft- 
ware control as previously explained. The 
CLEAR FIFO operation can also be performed 
under hardware control by defining the 
CLEAR pin of Port 2 as an input (Control 
Register 3, bit 7 = 1). 
__ 
For cascading purposes, the CLEAR pin can 
also be defined as an output (Control Register 
3, bit 7 = 0)' which reflects the current state 
of the CLEAR FIFO bit. It can then empty 
other FIOs or initialize other devices in the 
system. 
Data Direction Control. In CPU-to-I/O mode, 
the direction of data transfer can be controlled 
by the CPU side (Port 1) under software con- 
trol as preViously explained. The data direc- 
tion can also be determined by hardware con- 
trol by defining the Data Direction pin 
of Port 2 as an input (Control Register 3, 
bit 5 = 1). 
For cascading purposes, the Data Direction 
pin can also be defined as an output (Control 
Register 3, bit 5 = 0) pin which reflects the 
current state of the Data Direction bit. It can 
then be used to control the direction of data 
transfer for other FIOs or for external logic. 


On the Port 2 side, when data direction is 0, 
Port 2 is in Output Handshake mode. When 
data direction is I, Port 2 is in Input Hand- 
shake mode. 


CPU to I/O 
Operation 
(Continued) 
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DATA IN =:x 
VALID DATA 
X 
X 
VALID DATA X 


ACKIN 
\ 
1 
'-----I 


RFD 
, 
/ 
'-----I 


Figure 21. Interlocked Handshake Timing (Input) Port 2 Side Only 


DATA OUT =:x 
VALID DATA 
x'-___ ..JX 
VALID DATA X'-___ _ 
' ___ I 


,------'/ 


Figure 22. Interlocked Handshake Timing (Output) Port 2 Side Only 


DATA IN :=:x: 
VALID DATA 
X 
X VALID DATA X'-___ _ 


~~ J' 
/ 
,'-____ _ 


D~~ 
\ 
1 
'----I 


DAC 
OUT _______ --' 


Figure 23. Input (Acceptor) Timing IEEE-488 HS Port: Port 2 Side Only 


DATA OUT :=:x: 
VALID DATA 
X", ___ X VALID DATA X'-____ _ 


Dtu~ 
\ 
/ 


DAC 
IN _______ --' 


RFD --f 
IN 
' ____ ---'1 
,'------ 


Figure 24. Output (Source) Timing IEEE-488 HS Port: Port 2 Side Only 
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Programming 
The programming of the FlO is greatly 
simplified by the efficient grouping of the 
various operation modes in the control 
registers. Since all of the control registers are 
read/write, the need for maintaining their 
image in system memory is eliminated. Also, 
the read/write feature of the registers aids in 
system debugging. 
Each side of the FlO has 16 registers. All 16 
registers are used by the Port 1 side; Control 
register 2 is not used on the Port 2 side. All 
registers are addressable OH through F H. 
In the Z-BUS Low Byte mode, the FlO allows 
two methods for register addressing under con- 
trol of the Right Justify Address (RJA) bit in 
Control register O. When RJA = a, address 
bus bits 1-4 are used for register addressing 
and bits I, 5, 6, and 7 are ignored (Table 4). 
When RJA = I, bits 0-3 are used for the 
register addresses, and bits 4-7 are ignored. 


Control Registers. These four registers specify 
FlO operation. The Port 2 side control 


Non Z-iJUS 
D7-D4 
Da 


Z-BUS High 
Aa 


{ RJA=O 
AD7-ADS 
AD4 
Z-BUS Low 
RJA= 1 
A~-AD4 
ADa 


Description 


Contr9l Register a 
x 
a 


Control Register 1 
x 
a 
Interrupt Status Register a 
x 
a 


Interrupt Status Register 1 
x 
a 


Interrupt Status Register 2 
x 
a 


Interrupt Status Register 3 
x 
a 


Interrupt Vector Register 
x 
a 


Byte Count Register 
x 
a 


Byte Count Comparison 
Register 
x 


Control Register 2" 
x 


Control Register 3 
x 


Message Out Register 
x 


Message In Register 
x 


Pattern Match Register 
x 


Pattern Mask Register 
x 


Data Buffer Register 
x 


x = Don't Care 
"Register is only on Port I side 


registers operate only if the Port 2 device is a 
CPU. The Port 2 CPU can control interface 
operations, including data direction, only 
when enabled by the setting of bit a in the Port 
1 side of Control Register 2. A 1 in bit 1 of the 
same register enables the handshake logic. 


Interrupt Status Registers. These four 
registers control and monitor the priority 
interrupt functions for the FlO. 


Interrupt Vector Register. This register stores 
the interrupt service routine address. This vec- 
tor is placed on Do-D7 when IUS is set by the 
Interrupt Acknowledge Signal from the CPU. 
When bit 4 (Vector Includes Status) is set in 
Control Register a, the reason for the interrupt 
is encoded within the vector address in bits I, 
2, and 3. If bit 5 is set in Control register a, no 
vector is output by the FlO during an Interrupt 
Acknowledge cycle. However, IUS is set as 
usual. 


D2 
Dl 
DO 


A2 
Al 
Ao 


ADa 
AD2 
ADI 
ADo 
AD2 
ADI 
ADo 


a 
a 
a 
x 
a 
a 
x 
a 
a 
x 
a 
1 
x 
a 
a 
x 
a 
x 
a 
x 


x 


a 
a 
a 
x 


0 
a 
1 
x 
a 
a 
x 
a 
1 
1 
x 


0 
a 
x 
a 
x 


0 
x 


x 


Table 4. FlO Register Address Summary 
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Programming Byte Count Compare Register. This register 
(Continued) 
contains a value compared with the byte count 
in the Byte Count register. If the Byte Count 
Compare interrupt is enabled, an interrupt will 
occur upon compare. 


Message Out Register. Either CPU can place 
a message in its Message Out register. If the 
opposite side Message register interrupt is 
enabled, the receiving side CPU will receive 
an interrupt request, advising that a message 
is present in its Message In register. Bit 5 in 
Control Register 1 on the initiating side is set 
when a message is written. It is cleared when 
the message is read by the receiving CPU. 


Message In Register. This register receiv~s a 
message placed in the Message Out register by 
the opposite side CPU. 


Pattern Match Register. This register contains 
a bit pattern matched against the byte in the 


MASTER 


CPU 


NOTES: 


Z·BUS 


1. Data from master CPU - 
Z-FIO Port 2. 
2. Z-FIO Port 1 -DCP. 
3. DCP -RAM. 
4. RAM -Z-SCC. 
5. Z-SCC - 
data comm. line loop. 


Data Buffer register. When these patterns 
match, a Pattern Match interrupt will be 
generated, if previously enabled. 


Pattorn Mask Registor. The Pattern Mask 
register may be programmed with a bit pattern 
mask that limits comparable bits in the Pattern 
Match register to non-masked bits (l = mask). 


Data Buffer Register. This register contains 
the data to be read from or written to the 
FIFO buffer. 


Byte Count Register. This is a read-only 
register, containing the byte count for the 
FIFO buffer. The byte count is derived by sub- 
tracting the number of bytes read from the buf- 
fer from the number of bytes written into the 
buffer. The count is "frozen" for an accurate 
reading by setting bit 6 (Freeze Status register) 
in Control Register 1. This bit is cleared when 
the Byte Count register read is completed. 


Z·BUS 


1/ .... --"'--' '\ TO 
COMM. 
I'\r--,/ LINE 


Figure 25. Typical Application: Node Controller 
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N 
00 e w 
00 
N • 
tIS ... o 


Control Register 0 


Address: 0000 
(ReadlWrite) 


Control Register 2* 
Address: 1001 
(ReadlWrite) 


ID,ID,I~ E 
51D 
c4~1"'I"'I"~,="", 
. 


1 = RT J 
. UST. ADDRESS ( 


(Bll (Bol" 
RJA) 


g 
~ = Z·BUS CPU 
= NON Z 
. 
. 
~ 
0 
= 3.WIR/HU; CPU 
} 
PROGRAMS 


1 _ 
1 
= INTERLOC~'i'D HS 
PORT 2 MODE 


- 
VECTOR INCLUDES 
1 = NO VECTQjl 
STATUS (VIS) 


1 = DISABLE LO;N INTERRUPT (NV) 


I~I~I~I~I~I~I~I~I 
I 
~ ;: 'a'" """ .. "'" 
- PORT 2 SIDE ENABLE 


"THIS RE 
BITS 2-7 NOT USE 
HANDSHAKE 


O'S FRO~I~~ERRTREADS ALL 
MUST BE PROGRA~MED 


2 SIDE 
0 


Control Register 1 
Address: 0001 
(ReadIW rite) 


1 = INTERRU 
ER DAISY CHAIN (DLC) 


PTS ENABLED (MIE) 
Control Register 3 
Address: 10 10 
(ReadlWrite) 


1 


0 


,1 


0 
~'IO 
~~ID 
~410 
ll;31"~' 
111: = "a""""", .. ,,," 


= WAIT 


1 = REQUEST 


1 = START DMA 
- 
, 
1 = STOP OM 
ON BYTE COUNT 
. 


1 = MESSA 
A ON PATTERN MATCH 
GE MAILBOX 
~ : MESSAGE MAILBOX :::::~ER UNDER SERVICE" 


_ FREEZE STATU 
ER FULL" 


"READ.ONLY BITS 
NOT USED (MUST B S REGISTER COUNT 


1 
0 
,1 


0 
,1 


0 lli§51 
0 ~41D 
~31D 
~21~IID~ 
L 
PORT 2 SIDE-INPUT 
PORT 2 SIDE 
LINE" (PIN 33)"" 


NOT USED (~~UTPUT LINE (PIN 32)"" 


PORT 2 SIDE O~T BE PROGRAMMED 0) 


DATA DIREC~IO TPUT LINE (PIN 30)"" 


1 = INPUT TO N BIT 
O=OUTPUT F~6~ 
0= PORT 1 SIDE C 
CPU 
:= PORT 2 SIDE cg~~:g~~ DATA DIRECTION 


- CLEAR FIFO BUFFER 


" 
O=PORT 1 SIDE 
"~~AD.ONLY BITS 
1 =PORT 2 SIDE ggNTROLS CLEAR 
NL Y WHEN PO 
NTROLS 


E PROGRAMMED 0) 
RT 2 IS AN ItO PORT 


Control Registers 


Interrupt Status 
. 
Add 
RegIster· 0 


ress: 0010 


(ReadlWrite) 


Irl'II""""""~ 


NOT USED 


I 
~:UST BEPROGRAMMED 0) 


I 
I 
SSAGE INTERRUPT 
MESSAGE INTER 
PENDING (lP) 


RUPT EN 


IUS, IE, AND IP A 
MESSAGE INTERRUPT UNABLE (IE) 


THE FOLLOWING ~OWRITTEN USING 
DER SERVICE (IUS) 


Figure 27" 


NULL CODE 
MMAND: 


CLEAR IP & IUS 


SET IUS 


1 
CLEAR IUS 


o 
SET IP 


Interrupt Status Registers 


Registers 
(Continued) 
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Interrupt Status Register 1 
Address: 00 11 
(Read/Write) 


I D, I D,I Ds ! D41 D31 D, I D, I Do I 


DATA DIRECTION CHANGE INTERRUPT iJ I 


UNDER SERVICE (IUS) 
I 


DATA DIRECTION CHANGE INTERRUPT 
I 


ENABLE (IE) 
I 
I 


, 
I 


DATA DIRECTION CHANGE INTERRUPT 
PENDING (IP) 


IUS, IE, AND IP ARE WRITTEN USING 


THE FOLLOWING COMMAND: 


NULL CODE 
0 


CLEAR IP & IUS 
0 


SET IUS 
0 


CLEAR IUS 
0 


SET IP 
1 


CLEAR IP 
1 


SET IE 
1 


0 


1 


1 
1 


0 
0 


0 


1 


CLEAR IE 
1 
1 
1 


~ 
PATTERN MATCH INTERRUPT PENDING (IP) 
III L, -• .,.,,," .,"" "". 


I 
I 
PATTERN MATCH INTERRUPT ENABLED (IE) 


PATTERN MATCH INTERRUPT 
UNDER SERVICE (IUS) 
'------ NOT USED 
(MUST BE PROGRAMMED 0) 


IUS, IE, AND IP ARE WRITTEN USING 
THE FOLLOWING COMMAND: 


o 0 
0 
NULL CODE 


o 0 
1 
CLEAR IP & IUS 


o 1 
0 
SET IUS 


o 1 
1 
CLEAR IUS 


1 
0 
0 
SET IP 


1 
0 
CLEAR IP 


1 
1 
SET IE 


1 
1 
1 
CLEAR IE 


'RE"D·ONLY BITS 


Interrupt Status Register 2 
Address: 0100 
(Read/W rite) 


I 0, I 0, t 0,1 04 t D3l 0, I D, I Do I 


BYTE COUNT COMPARE INTERRUPT iJ I 


UNDER SERVICE (IUS) 
I 
I 


BYTE COUNT COMPARE INTERRUPT 


ENABLE (IE) 
I 
I 


BYTE COUNT COMPARE INTERRUPT 
I 
I 
PENDING (IP) 


IUS, IE, AND IP ARE WRITTEN USING 


THE FOLLOWING COMMAND: 


NULL CODE 


CLEAR IP & IUS 


SET IUS 


CLEAR IUS 


SET IP 


CLEAR IP 


SET IE 


CLEAR IE 


0 


0 


0 


0 


1 


1 


1 


1 


0 
0 


0 


1 


1 
1 


0 
0 


0 


1 


1 
1 


lblli~ 


L UNDERFLO~ ERROR' 
L 
ERROR INTERRUPT PENDING (10) 


I 
ERROR INTERRUPT ENABLED (IE) 


I 
I 
ERROR INTERRUPT UNDER SERVICE (IUS) 


I 
I 
I 
OVERFLOW ERROR' 


IUS, IE, AND IP ARE WRITTEN USING 
THE FOLLOWING COMMAND: 


o 0 
0 
NULL CODE 


o 0 
1 
CLEAR IP & IUS 


o 1 
0 
SET IUS 


o 1 
1 
CLEAR IUS 


1 
0 
0 
SET IP 


1 
0 
CLEAR IP 


1 
1 
SET IE 


1 
1 
1 
CLEAR IE 


'READ·ONLY BITS 


Interrupt Status Register 3 
Address: 0101 
(Read/Write) 


I 0, I 0, i Ds I 0 4 i 0 3 1 0, I D, I Do I 


'"" ,",,","no"," "'''''''"'' ~ I I 


FULL INTERRUPT ENABLE (IE) ~ 
I 
I 


FULL INTERRUPT PENDING (IP) 


IUS, IE, AND IP ARE WRITTEN USING 


THE FOLLOWING COMMAND: 


NULL CODE 
0 
0 
0 


CLEAR IP & IUS 
0 
0 
1 


SET IUS 
1 
0 


CLEAR IUS 
1 
1 


SET IP 
1 
0 
0 


CLEAR IP 
1 
0 
1 


SET IE 
1 
1 
0 


CLEAR IE 
1 
1 
1 


lblli~ 


' L BUFFER EMPTY' 
~ 
EMPTY INTERRUPT PENDING (IP) 


EMPTY INTERRUPT ENABLE (IE) 


I 
I 
EMPTY INTERRUPT UNDER SERVICE (IUS) 
I 
I 
I 


BUFFER FULL' 


IUS, IE, AND IP ARE WRITTEN USING 
THE FOLLOWING COMMAND: 


o 0 
0 
NULL CODE 


o 0 
1 
CLEAR IP & IUS 


o 
1 
0 
SET IUS 


o 1 
1 
CLEAR IUS 


1 
0 
0 
SET IP 


1 
0 
1 
CLEAR IP 


1 
1 
0 
SET !E 


1 
1 
1 
CLEAR IE 


• READ·ONL Y BITS 


Figure 27. Interrupt Status Registers (Continued) 
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Byte Count Register 
Address: 0111 
(Read Only) 


1071 0.1 051 0.1 031 0,1 0, I 0.1 
I I I I I I I I 
REFLECTS NUMBER OF BYTES IN BUFFER 


Figure 28. Byte Count Register 


Pattern Match Register 
Address: II 0 1 
(ReadJW rite) 


I~I~I~I~I~I~I~I~I 
I I I I I I I I 
STORES BYTE COMPARED WITH 
BYTE IN DATA BUFFER REGISTER 


Figure 30. Pattern Match Register 


Data Buffer Register 
Address: 1111 
(ReadJWrite) 


107\ 0.\ 05 \ 0.\ 03 \ 0,\ 0, 1.0.1 
I I I I I I I I 


CONTAINS THE BYTE TRANSFERRED 


TO OR FROM FIFO BUFFER RAM 


Figure 32. Data Buffer Register 


Message Out Register 
Address: 10 11 
(ReadJWrite) 


I~I~I~I~I~I~I~I~I 
I I I I I I I I 


STORES MESSAGE SENT TO MESSAGE 
IN REGISTER ON OPPOSITE PORT OF FlO 


Figure 34. Message Out Register 


VECTOR STATUS 


Interrupt Vector Register 
Address: 0110 
(ReadJW rite) 


I I I I 


1 


NO INTERRUPTS PENDING 


BUFFER EMPTY 


BUFFER FULL 


OVER/UNDERFLOW ERROR 


BYTE COUNT MATCH 


PATTERN MATCH 
1 
0 
1 


DATA DIRECTION CHANGE 
1 
1 
0 


MAILBOX MESSAGE 
1 
1 
1 


Figure 29. Interrupt Vector Register 


Pattern Mask Register 
Address: 1110 
(ReadJWrite) 


1071 0.1 0,1 0.\ 03 \ 0,\ 0, \ 0.1 
I I I I I I I I 


IF SET, BITS 0·7 MASK BITS 0-7 
IN PATTERN MATCH REGISTER. 
MATCH OCCURS WHEN ALL 
NON·MASKED BITS AGREE. 


Figure 31. Pattern Mask Register 


Byte Count Comparison Register 
Address: 1000 
(ReadJWrite) 


I~I~I~\~\~I~I~I~I 
I I I I I I I I 


CONTAINS VALUE COMPARED TO BYTE COUNT 
REGISTER TO ISSUE INTERRUPTS ON MATCH 


. 
(BIT 7 ALWAYS 0.) 


Figure 33. Byte Count Comparison Register 


Message In Register 
Address: 1100 
(Read Only) 


I~!~!~!~I~I~I~I~I 
II I I I I I I 


STORES MESSAGE RECEIVED FROM MESSAGE 
OUT REGISTER ON OPPOSITE PORT OF CPU 


Figure 35. Message In Register 


2020·025,026,027,028,029,030,031,032 


Absolute 
Maximum 
Ratings 


Standard 
Test 
Conditions 


DC 
Charac- 
teristics 


Capacitance 


Inputs 


8085-0209, 0002 


Voltages on all inputs and outputs 
with respect to GND .......... -0.3 V to + 7.0 V 
Operating Ambient 
Temperature ................. ooe to + 70°C 
Storage Temperature ........ -65°C to + 150 °e 


The characteristics below apply for the 
following standard test conditions, unless 
otherwise noted. All voltages are referenced to 
GND. Positive current flows into the refer- 
enced pin. Standard conditions are as follows: 


+5V 


2.2K 


Standard Test Load 


Symbol 
Parameter 
Min 


VIH 
Input High Voltage 
2.0 


V1L 
Input Low Voltage 
-0.3 


VOH 
Output High Voltage 
2.4 


VOL 
Output Low Voltage 


IlL 
Input Leakage 
-10.0 


IaL 
Output Leakage 
-10.0 


ILM 
Mode Pins Input Leakage 
(Pins 19 and 21) 


-100 


Icc 
Vee Supply Current 


Stresses greater than those listed under Absolute Maxi- 


mum Ratings may cause permanent damage to the device. 
This is a stress rating only; operation of the device at any 
condition above those indicated in the operational sections 
of these specifications is not implied. Exposure to absolute 
maximum rating conditions for extended periods may affect 
device reliability. 


c +4.75 V ~ Vee ~ +5.25 V 
Ii GND = 0 V 


Ell TA as specified in Ordering Information 


+5V 


FROM OUTPUT 
UNDER TEST d 


2.2K 


Max 


Vcc +0.3 


0.8 


0.4 


0.5 


+ 10.0 


+ 10.0 


+ 10.0 


200 


50 PFr 


Open.Drain Test Load 


Unit 


V 


V 


V 


V 


V 
p,A 


p,A 


p,A 


rnA 


Condition 


IOH = - 250 JtA 
IOL = +2.0 rnA 


IOL = +3.2 rnA 
0.4 ::; VIN ::; + 2.4V 


0.4 ::; VOUT ::; +2.4V 


O<VIN<Vcc 


Vee = 5 V ± 5% unless otherwise speCified, over speCified temperature range. 


Symbol 
Parameter 
Min 
Max 
Unit 
Test Condition 


CIN 
Input Capacitance 
10 
pF 


COUT 
Output Capacitance 
15 
pF 
Unmeasured Pins 


Cvo 
Bidirectional Capacitance 
20 
pF 
Returned to Ground 


tr 
Any Input Rise Time 
100 
ns 


tf 
Any Input Fall Time 
100 
ns 


f = 1 MHz, over speCified temperature range. 
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AC Characteristics 


No. 
Symbol 
Parameter 


TwAS 
AS Low Width 


2 
TsA(AS) 
Address to AS t Setup Time 


3 
ThA(AS) 
Address to AS t Hold Time 


4 
TsCSO(AS) 
CS to AS t Setup Time 


5 - 
ThCSO(AS) - 
CS to AS t Hold Time 


6 
TdA.S(DS) 
AS t to DS t Delay 


7 
TsA(DS) 
Address to DS 1 (with AS t to DS 1 = 60 ns) 


8 
TsRWR(DS) 
R!W (Read) to DS 1 Setup Time 


9 
TsRWW(DS) 
R!W (Write) to DS 1 Setup Time 


10-TwDS 
DS Low Width 


11 
TsDW(DSf) 
Write Data to DS 1 Setup Time 


12 
TdDS(DRV) 
DS (Read) 1 to Address Data Bus Driven 


13 
TdDSf(DR) 
DS 1 to Read Data Valid Delay 


14 
ThDW(DS) 
Write Data to DS t Hold Time 


15 - 
TdDSr(DR) -- DS t to Read Data Not Valid Delay 


16 
TdDS(DRz) 
DS t to Read Data Float Delay 


17 
ThRW(DS) 
RlW to DS t Hold Time 


18 
TdDS(AS) 
DS t to AS 1 Delay 


19 
Trc 
Valid Access Recovery Time 


NOTES: 
I. Parameter does not apply to Interrupt Acknowledge trans· 


actions. 
2. Float delay Is measured to the time when the output has 
changed 0.5 V from steady state with minimum as load and 
load and maximum dc load. 


RlW 


READ -----H-' 


R1W 


4 MHz 
6 MHz 
Min 
Max 
Min 
Max 
Notes*t 


70 
50 


30 
10 


50 
30 


0 
0 


60 
40 -------1- 


60 
40 


120 
100 


100 
80 


0 
0 


390 
250 


30 
20 


0 
0 


250 
180 


30 
20 


0 
0 


70 
45 
2 


55 
40 


50 
25 


1000 
650 
3 


3. This is the delay from DS of one CIa access to Os of another 


FLO access (either read or write). 


• All timing references assume 2.0 V for a logic "I" and 0.8 V for 
a logic "0". All timings are preliminary and subject to change. 
r Units in nanoseconds (ns). 


WRITE ____ -+-I-__ +~-+--------+_~------__:--- 


Figure 3S. Z-BUS CPU Interface Timing 
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AC Characteristics 
4MHz 
SMHz 


No. 
Symbol 
Parameter 
Min 
Max 
Min 
Max 
Notes*t 


20 
TsIA(AS) 
INTACK to AS t Setup Time 
0 
0 


21 
ThIA(AS) 
INTACK to AS t Hold Ti~e 
250 
250 


22 
TsDSA(DR) 
DS (Acknowledge) I to Read Data Valid Delay 
250 
180 


23 
TwDSA 
DS (Acknowledge) Low Width 
390 
250 
24-TdAS(lEO)-- AS t to lEO I Delay (INTACK Cycle)--------350 
250 ----4- 


25 
TdIEI(IEO) 
lEI to lEO Delay 
26 
TslEI(DSA) 
lEI to DS (Acknowledge) I Setup Time 
27 
ThIEI(DSA) 
lEI to iSS (Acknowledge) t Hold Time 
28 
TdDS(INT) 
DS (INTACK Cycle) to INT Delay 


29 
TdDCST 
Interrupt Daisy Chain Settle Time 


NOTES: 
4. The parameters for the devices in any particular da~ chaJ!! 


must meet the following constraint: The delay from AS to DS 
must be greater than the sum of TdAS(IEO) for the highest 
priority peripheral, TslEI(DSA) for the lowest priority peripheral 


ADo-AD7 
UNDEFINED 


f4-------(29l----~~ 


lEI 


lEO 


150 
100 
4 


100 
70 
50 
30 
4 


900 
800 


4 


and TdIEl(lEO) for each peripheral, separating them in the 
chain. 


• Timings are preliminary and subject to change. 
t Units in nanoseconds (ns). 


f..-------i2Jl-----.! 


Figure 37. Z-BUS CPU Interrupt Acknowledge Timing 
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AC Characteristics 


No. 
Symbol 


30 


31 
32 


TdMW(INT) 
TdDC(INT) 
TdPMW(INT) 


Parameter 


Message Write to INT Delay 
Data Direction Change to INT Delay 
Pattern Match to INT Delay (Write Case) 


33 
TdPMR(1NT) 
Pattern Match (Read Case) to INT Delay 


4 MHz 
6 MHz 
Min 
Max 
Min 
Max 
Notes*t 


5 


6 


34-TdSC(INT)--Status Compare to INT Delay------------ 
----6- 


35 
TdER(INT) 
Error to INT Delay 
36 
TdEM(INT) 
Empty to INT Delay 


37 
38 


NOTES: 


TdFL(INT) 
TdAS(INT) 
Full to INT Delay 
AS to INT Delay 


5 .. Write is from the other side of FLO. 
6. Write can be from either side, depending on programming 
of FLO. 


MESSAGE 
WRITE 
WRITE 
MESSAGE 
REGISTER 
OUT 


DATA 
WRITE 
DIRECTION 
CONTROL 


CHANGE 
REGISTER 3 


WRITE DATA 
BUFFER 
REGISTER 
PAnER" I 
MATCH 
READ DATA 
BUFFER 
REGISTER 


STATUS 
WRITE OR READ 
COMPARE 
DATA BUFFER 
REGISTER 


ERROR 
WRITE OR READ 
DATA BUFFER 
REGISTER 


EMPTY 
READ DATA 
BUFFER 
REGISTER 
I 


FULL 
WRITE DATA 
BUFFER 
REGISTER 


AS 


INT 


OS' 


os" 


os 


OS 


Os" 


OS 


OS' 


• Timings are preliminary and subject to change. 
t Units equal to AS Cycles + ns. 


I~------~~~-------'I 


~--------~~r---------~ 


t-+-----------{31}--'--------~ 


1~-----------4~}-----~----~ 


Figure 38. Z-BUS Interrupt Timing 
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AC Characteristics 
4MHz 
6MHz 
No. 
Symbol 
Parameter 
Min 
Max 
Min 
Max 


1 
TdDS(WAIT) 
AS I to WAIT 1 Delay 
190 
160 


2 
TdDSl(WAIT) 
DSI I to WAIT I Delay 
1000 
1000 


3 
TdACK(WAIT) 
ACKIN 1 to WAIT I Delay 
1000 
1000 
4-TdDS(REQ)--DS 1 toREQ I Delay------------- 350 
300 


5 
T dDMA(REQ) 
DMASTB 1 to REQ I Delay 
350 
300 


6 
TdDSl(REQ) 
DSI I to REQ 1 Delay 
1000 
1000 


7 
TdACK(REQ) 
ACKIN 1 to REQ 1 Delay 
1000 
1000 


8 - 
TdSU(DMA) -- Data Setup Time to DMASTB -------- 200 
150 


9 
TdH(DMA) 
Data Hold Time to DMASTB 
30 
20 


10 
TdDMA(DR) 
DMASTB 1 to Valid Data 
150 
100 


11 
TdDMA(DRH) 
DMASTB I to Data Not Valid 
0 
0 


12 
TdDMA(DR2) 
DMASTB I to Data Bus Float 
70 
45 


NOTES: 
1. The delay is from DAV for 3-Wire Input Handshake. The delay 
is from DAC for 3-Wire Handshake. 


• Timings are preliminary and subject to change. 
t Units in nanoseconds (ns). 


is 


OS 
DATA 
READ/WRITE 
BUFFER 


BY OTHER SIDE 
REGISTER 


DSI 
DATA 


WRITE/READ 
BUFFER 


BY OTHER SIDE 
REGISTER 


WAIT 


ACKIN 
INPUT/ 
OUTPUT 
PORT 


DMASTB 


REQ 
IN/OUT 


DATA 
DATA 


FROM 
BUFFER 
FlO 
REGISTER 


DMASTB 


WRITE 
DATA 


TO 
BUFFER 
flO 
REGISTER ---t:=~~-------- 


AC Characteristics 


No. 
Symbol 


1 
2 
3 


NOTES: 


TdDSQ(AS) 
TdASQ(DS) 
Tw(AS + DS) 


Figure 39. Z-BUS Request/Wait Timing 


Parameter 


Delay from DS I to AS 1 for No Reset 
Delay for AS I to DS 1 for No Reset 
Minimum Width of AS and DS Both Low for Reset. 


Min 


40 
50 
500 


4MHz 
Max 
6 MHz 
Min 


20 
30 
350 


Max 


1. Internal circuitry allows for the reset provided by the Z8 (DS 


held Low while AS pulses) to be sufficient. 


• Timings are preliminary and subject to change. 
t Units in nanoseconds (ns). 


Figure 40. Z-BUS Reset Timing 


2020-037, 038 


Notes*t 


Notes*t 
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AC Characteristics 
4 MHz 
6 MHz 
No. 
Symbol 
Parameter 
Min 
Max 
Min 
Max 
Notes*t 


TsA(RD) 
Address Setup to RD I 
80 
80 


2 
TsA(WR) 
Address. Setup to WR I 
80 
80 


3 
ThA(RD) 
Address Hold Time to RD t 
a 
a 


4 -ThA(WR).--Address Hold Time to WR t 
a 
a 


5 
TsCEI(RD) 
CE Low Setup Time to RD 
a 
a 


6 
TsCEI(WR) 
CE Low Setup Time to WR 
a 
a 


7 
ThCEI(RD) 
CELow Hold Time to RD 
a 
a 


8 - 
ThCEI(WR) -- CE Low Hold Time to WR 
a 
a 


9 
TsCEh(RD) 
CE High Setup Time to RD 
100 
70 


10 
TsCEh(WR) 
CE High Setup Time to WR 
100 
70 


11 
TwRD1 
RD Low Width 
390 
250 


12 - 
TdRD(DRA) -- RD I to Read Data Active Delay 
a 
a 


13 
TdRDf(DR) 
RD I to Valid Data Delay 
250 
180 


14 
TdRDr(DR) 
RD t to Read Data Not Valid Delay 
a 
a 


15 
TdRD(DRz) 
RD t to Data Bus Float 
70 
45 
2 
16 ~TwWRl 
WR Low Width 
390 
250 


17 
TsDW(WR) 
Data Setup Time to WR 
a 
a 


18 
ThDW(WR) 
Data Hold Time to WR 
30 
20 


19 
Trc 
V alid Acce~s Recovery Time 
1000 
650 
3 


NOTES: 
1. Parameter does not apply to Interrupt Acknowledge trans- 
3. Thi£!..s the delay from RD I to WR I of one FlO access to Fill I 


actions. 
or WR I of another FlO access. 
2. Float delay is measured to the time the output has changed 
• Timings are preliminary and subject to change. 


0.5 V from steady state with minimum ac load and maximum dc 
t Units in nanoseconds (ns). 
load. 
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C/O 


FI~~~~~ ------+--+---i--~ __ --' 


Do-D7 


FlO WRITE 
DATA VALID 
------' 


Figure 41. Non-Z-BUS CPU Interface Timing 


Ci! ~ 
l~,--__ 
_ 


l--t" ~.\,--_®=- 
r----f-f--' =-::aJ _____ _ 


RD OR WR ---'" 
_ 
! 
) 
"- 


Figuro 42. Non-Z-BUS Interface Timimg 
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AC Characteristics 


No. 
Symbol 
Parameter 


20 
TdIEl(IEO) 
IEI to IEO Delay 


21 
TdI(IEO) 
INTACK 1 to IEO 1 Delay 


22 
TsIEI(RDA) 
IEI Setup Time to RD (Acknowledge) 


23 
TdRD(DR) 
RD 1 to Vector Valid Delay 
24-TwRD1(IA)--Read Low Width (Interrupt Acknowledge) 


25 
ThIA(RD) 
INTACK I to RD I Hold Time 


26 
ThIEI(RD) 
IEI Hold Time to RD I 


27 
TdRD(INT) 
RD I to INT I Delay 


28 
TdDCST 
Interrupt Daisy Chain Settle Time 


NOTES: 
4. The parameter for the devices in any particular daisy chain 
must meet the following constraint: The delay from 
INTACK I to Fill I must be greater than the sum of 
TdINA(lEO) for the highest priority peripheral, TsIEI(RD) 


DO-D7------------------~--------~~ 


lEI 


I~O 


4 MHz 
6 MHz 
Min 
Max 
Min 
Max 
Notest* 


150 
100 
350 
250 
100 
70 
250 
180 


390 
250 
30 
20 
20 
10 


900 
800 


350 
250 


for the lowest priority peripheral. and TdIEl(IEO) for each 
peripheral separating them in the chain. 
r Units in nanoseconds (n5). 
• Timings are preliminary and subject to change. 


4 


4 


4 


4 


Figure 43. Non-Z-BUS Interrupt Acknowledge Timing 
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AC Characteristics 
4MHz 
6 MHz 
No. 
Symbol 
Parameter 
Min 
Max 
Min 
Max 
Notes*t 


29 
TdMW(INT) 
Message Write to INT Delay 
5,6 


30 
TdDC(INT) 
Data Direction Change to INT Delay 
5,7 


31 
TdPMW(INT) 
Pattern Match (Write Case) to INT Delay 
5 
32-TdPMR(INT)--Pattern Match (Read Case) to INT Delay--------------------5- 


33 
TdSC(INT) 
Status Compare to INT Delay 
5,7 


34 
35 
36 
37 


NOTES: 


TdER(INT) 
TdEM(INT) 
TdFL(INT) 
TdSO(INT) 


Error to INT Delay 
Empty to INT Delay 


Full to INT Delay 
State 0 to INT Delay 


5. Delay number is valid for State 0 only. 
6. Write is from other side of FlO. 
7. Write can be from either side, depending on programming of 


FlO. 


MESSAGE 
WRITE 
WRITE 
MESSAGE 
REGISTER 
OUT 


DATA 
WRITE 
DIRECTION 
CONTROL 


CHANGE 
REGISTER 3 


r"'"'' 


BUFFER 
REGISTER 


PATTERN 
MATCH 
READ DATA 
BUFFER 
REGISTER 


STATUS 
WRITE OR READ 


COMPARE 
DATA BUFFER 
REGISTER 


ERROR 
WRITE OR READ 
DATA BUFFER 
REGISTER 


EMPTY 
READ DATA 
BUFFER 
REGISTER 


FULL 
WRITE DATA 
BUFFER 
REGISTER 


ST1-STo 


INT 


WRC.5 


WRc.s 


WRC 


RDc 


WR4 .• 0R RDc .• 


WRcORRD 


RDc.s 


WRc.s 


WRC_RD4 


\1- 


* Timings are preliminary and subject to change. 
t Units in nanoseconds (ris). 


r-w-- 
r 


{ 
® 
• 


I" 
® 
• 
I r---- 


33 


C 
. 


35 


'i' 


t=® • 
I 
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Figure 44. Z-FIO Non-Z-BUS Interrupt Timing 
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AC Characteristics 
4MHz 
No. 
Symbol 
Parameter 
Min 
Max 


TdRD(WT) 
CE l to WAIT Active 
200 


2 
TdRDl(WT) 
RD1 t or WR1 t to WAIT Inactive 
1000 


3 
TdACK(WT) 
ACKIN l to WAIT Inactive 
1000 


4-TdRD(REO)--RD l or WR l to REO Inactive ----------- 350 
5 
TdRDl(REO) 
RD1 t or WR1 t to REO Active 
6 
TdACK(REO) 
ACKIN l to REO Active 
7 
TdDAC(RD) 
DACK l to RD l or WR l 
8-TSU(WR)---Data Setup Time to WR----------- 
9 
Th(WR) 
Data Hold Time to WR 
10 


11 
12 


NOTES: 


TdDMA 
TdDMA(DRH) 
TdDMA(DRZ) 


RD l to Valid Data 


RD t to Data Not Valid 


RD t to Data Bus Float 


1000 
1000 
100 
200 
30 
150 
0 
70 


6MHz 
Min 
Max 


170 
1000 
1000 
300 
1000 
1000 
80 


20 
100 
0 


45 


.1. The delay is from DAV I for 3-Wire Input Handshake. The 
delay is from DAC t for 3-Wire Input Handshake. 


• Timings are preliminary and subject to change. 


2. Only when DACK is active. 


2020-043 


RD/WR 


READ/WRITE OF DATA 
BUFFER REGISTER 


WR,/RD1 


WRITE/READ OF DATA 
BUFFER REGISTER 
BY OTHER SIDE 


ACKIN 


INPUT/OUTPUT PORT 


DATA FROM FlO 


FlO WRITE TO DATA 
BUFFER REGISTER 


r Units in nanoseconds (ns). 


I~--~CD)-----I 


--)t~-: ---- 


Figure 45. Non-Z-BUS Request/Wait Timing 


Notes*t 


2 
2 
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AC Characteristics 


No. 
Symbol 
Parameter 


TdWR(RD) 
Delay from WR f to RD ! 


2 
TdRD(WR) 
Delay from RD f to WR ! 


3 
TwRD + WR 
Width of RD and WR, both Low for Reset 


NOTES: 
• Timings are preliminary and subject to change. 
r Units in nanoseconds (ns). 


Min 


100 
100 
500 


Figure 46. Non-Z-BUS Reset Timing 


AC Characteristics 


No. 
Symbol 
Parameter 


TwCLR 
Width of Clear to Reset FIFO 


2 
TdOE(DO) 
OE ! to Data Bus Driven 
3 
TdOE(DRZ) 
OE f to Data Bus Float 


NOTES: 
• Timings are preliminary and subject to change. 
r Units in nanoseconds (ns). 


CLEAR~~¥ 
INPUT 
/ 


DATA OUT 


Min 


700 


a 


Figure 47. Port 2 Side Operation 
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I 


/ 


4MHz 
Max 


4MHz 
Max 


6 MHz 
Min 
Max 


70 
70 
350 


6MHz 
Min 
Max 


700 


a 


Notes*t 


Notes*t 
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AC Characteristics 
4MHz 
No. 
Symbol 
Parameter 
Min 
Max 


.TsDI(ACK) 
Data Input to ACKIN I to Setup Time 
50 


2 
TdACKf(RFD) 
ACKIN I to RFD I Delay 
a 
500 


3 
T dRFDr(ACK) 
RFD 1 to ACKIN I Delay 
a 
4-TsDO(DAV)--Data Out to DAV I Setup Time 
50 


5 
TdDAVf(ACK) 
DA V I to ACKIN I Delay 
a 


6 
ThDO(ACK) 
Data Out to ACKIN Hold Time 
50 


7 
TdACK(DAV) 
ACKIN I to DA V 1 Delay 
a 
500 


8-ThDI(RFD)--Data Input to RFD I Hold Time 
a 


9 
T dRFDf(ACK) 
RFD I to ACKIN 1 Delay 
a 


10 
TdACKr(RFD) 
ACKIN 1 (DAV I) to RFD 1 Delay-Interlocked and 
3-W ire Handshake 
a 
400 


11 
TdDAVr(ACK) 
DAV 1 to ACKIN 1 (RFD I) 
a 
12-TdACKr(DAV)-ACKIN 1 to DAV I 
0--800 


13 
TdACKf(Empty) ACKIN I to Empty 
a 


14 
TdACKf(Full) 
ACKIN I to Full 
a 


15 
TcACK 
ACKIN Cycle Time 


NOTES: 
• Timings are preliminary and subject to change. 
t Units in nanoseconds (ns), except as noted. 
1. Units in microseconds. 


DATA 


EMPTY 


FULL 
~\'------ 


Figure 48. 2-Wire Handshake (Port 2 Side Only) Output 


DATA =>t 
-cD- 


VALID DATA 


RFD 


EMPTY 


I~.r---------~®~--------~~I 
~I~k---_- 


FULL 


Figure 49. 2-Wire Handshake (Port 2 Side Only) Input 


2020-046, 047 


6 MHz 
Min 
Max 


50 
a 
500 


a 


25 
a 


50 
a 
500 


a 
a 


a 
400 


a 
0--800 
a 
a 


Notes*t 
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AC Characteristics 
4 MHz 
6 MHz 
No. 
Symbol 
Parameter 
Min 
Max 
Min 
Max 
Notes*t 


1 
TsDI(DAV) 
Data Input to DA V f Setup Time 
50 
50 


2 
TdDAVIf(RFD) 
DA V f to RFD f Delay 
a 
500 
a 
500 


3 
TdDAVf(DAC) 
DAV f to DAC t Delay 
a 
500 
a 
500 


4-ThDI(DAC)--Data In to DAC t Hold Time 
a 
a 


5 
TdDACIr(DAV) DAC t to DA V t Delay 
a 
a 


6 
TdDAVIr(DAC) DAV t to DAC f Delay 
a 
500 
a 
500 


7 
T dDAVIr(RFD) 
DA V t to RFD t Delay 
a 
500 
0 
500 


8-TdRFDI(DAV)-RFD t to DAV f Delay 
a 
a 


9 
TsDO(DAC) 
Data Out to DAV f 


10 
TdDAVOf(RFD) DA V f to RFD f Delay 
a 
a 


11 
TdDAVOf(DAC) DAV f to DAC t Delay 
a 
a 
12-ThDO(DAC)--Data Out to DAC t Hold Time ------------------------ 


13 
TdDACOr(DAV) DAC t to DAV t Delay 


14 
TdDAVOr(DAC) DAV t to DAC f Delay 


15 
TdDAVOr(RFD) DAV t to RFD t Delay 


16 
TdRFDO(DAV) 
RFD t to DAV f Delay 


NOTES: 
• Timings are preliminary and subject to change. 
t Units in nanoseconds (ns). 
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Figure 50. 3-Wire Handshake Input 
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Figure 51. 3-Wire Handshake Output 
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Ordering 
Product 
Package/ 
Product 
Package/ 
Information 
Number 
Temp 
Speed 
Description 
Number 
Temp 
Speed 
Description 


Z8038 
CE 
4.0 MHz 
Z-FIO (40-pin) 
Z8038A 
CM 
6.0 MHz 
Z-FIO (40-pin) 


Z8038 
CM 
4.0 MHz 
Same as above 
Z8038A 
CMB 
6.0 MHz 
Same as above 


Z8038 
CMB 
4.0 MHz 
Same as above 
Z8038A 
CS 
6.0 MHz 
Same as above 


Z8038 
CS 
4.0 MHz 
Same as above 
Z8038A 
DE 
6.0 MHz 
Same as above 


Z8038 
DE 
4.0 MHz 
Same as above 
Z8038A 
DS 
6.0 MHz 
Same as above 


Z8038 
DS 
4.0 MHz 
Same as above 
Z8038A 
PE 
6.0 MHz 
Same as above 


Z8038 
PE 
4.0 MHz 
Same as above 
Z8038A 
PS 
6.0 MHz 
Same as above 


Z8038 
PS 
4.0 MHz 
Same as above 


NOTES: C = Ceramic, D = Cerdip, P = Plastic; E = -40°C to +85°C, M = 55°C to + 125°C, MB = -55°C to l25°C with MIL-STD-883 
with Class B processing, S = O°C to +70°C. 
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Features 


General 
Description 
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lJ Bidirectional, asynchronous data transfer 
capability 


El Large 128-bit-by-8-bit buffer memory 


[J Two-wire, interlocked handshake protocol 
c Wire-ORing of empty and full outputs for 
sensing of multiple-unit buffers 


The Z8060 First-In First-Out (Z-FIFO) Buffer 


Unit consists of a 128-bit-by-8-bit memory, 
bidirectional data transfer and handshake 
logic. The structure of the Z-FIFO unit is 
similar to that of other available buffer units. 
Z-FIFO is a general-purpose unit; its hand- 
shake logic is compatible with that of other 
members of Zilog's Z8 and Z8000 Families. 


Z-FIFOs can be cascaded end-to-end without 
limit to form a parallel 8-bit buffer of any 
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[] 3-state data outputs 


[J Connects any number of FIFOs in series to 
form buffer of any desired length 


C Connects any number of FIFOs in parallel 
to form buffer of any desired width 


desired length (in 128-byte increments). Any 
number of single- or multiple-unit Z-FIFO 
serial buffers can be connected in parallel to 
form buffers of any desired width (in 8-bit 
increments) . 
The Z-FIFO buffer units are available d~ 


28-pin packages. Figures 1 and 2 show the pin 
functions and pin assignments, respectively, of 
the Z-FIFO"device. A block diagram is shown 
in Figure 3. 


RFO/OAVA 
+5V 


ACKINA 
RFOIDAVB 


FULL 
ACKINB 


EMPTY 
CLEAR 


DEA 
OIRA/B 


OOA 
DEB 


D'A 
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D3A 
D2S 
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D6A 
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Figure 2. FIFO Pin Assignments 
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General 
Description 
(Continued) 
DATA ,'--_ 
..... , I 
BUS 
A '_-_II 


CONTROL , ....... _ 
.. on I 


AND 


STATUS 


DATA 
BUS 


B 


,,---, CONTROL 


AND 


STATUS 


Figure 3. Functional Block Diagram 


Pin 
ACKIN. Acknowledge Input (input, active 
Descriptions 
Low). This line signals the FIFO that output 
data has been received by peripherals or that 
input data is valid. 
CLEAR. Clear Buffer (input, active Low). 
When set to Low, this line causes all data to be 
cleared from the FIFO buffer. 


Do-I>,. Data Bus (inputs/outputs, bidirec .. 
tional). These bidirectional lines are used by 
the FIFO to receive and to transmit data. 
DIR AlB. Direction Input AlB (input, two con .. 
trol states). A High on tHis line signals that 
input data is to be received at Port B. A Low 
on this line signals that input data is to be 
received at Port A. 
EMPTY. Buffer Status (output, active High, 
open .. drain). A High on this line indicates that 
the FIFO buffer is empty. 


Functional 
Interlocked 2-Wire Handshake. In inter .. 
Description 
locked 2 .. wire handshake operation, the action 
of FIFO must be acknowledged by the other 
half of the handshake before the next action 
can occur. In an Output Handshake mode, the 
FIFO indicates that new data is available only 
after the external device has indicated that it is 
ready for the data. In an Input Handshake 
mode, the FIFO does not indicate that it is 
ready for new data until the data source indi .. 


DATA IN =:x 
VALID DATA 
X 


ACKIN 
\ 
I 


RFD 
\ 


FULL. Buffer Status (output, active High, 
open .. drain). A High on this line indicates that 
the FIFO buffer is full. 


OEA" OEB. Output Enable A, Output Enable 
B (inputs, active Low). When Low, OEA 
enables the bus drivers for Port A;' when High, 
OEA causes the bus drivers to float to a high .. 
impedance level. Input OEB controls the bus 
drivers for Port B in the same manner as OEA 
controls those for Port A. 
RFD/DAV. Ready .. /or .. DataIData Available 
(outputs RFD, active High; DAV active Low). 
RFD, when High, signals to the peripherals 
involved that the FIFO is ready to receive 
data. DAV, when Low, signals to the 
peripherals involved that FIFO has data 
available to send. 


cates that the previous byte of the data is no 
longer available, thereby acknowledging the 
acceptance of the last byte. This control 
feature allows the FIFO, with no external 
logiC, to directly interface wi'th the port of any 
CPU in the 28 Family-a CIO, a UPC, an FlO, 
or another FIFO. The timing for the input and 
output handshake operations is shown in 
Figures 4 and 5, respectively. 


X 


VALID DATA X 
'--I 
I 
'--I 


Figure 4. Two .. Wire 'Interlocked Handshake Timing (input) 


DATAOUT=:x _______ 
VA_L_ID_D_AT_A ____ -JX 
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C 
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~ 


\~ __ 
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Figure 5. Two .. Wire Interlocked Handshake Timing (output) 
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Functional 
Description 
(Continued) 
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Resetting or Clearing the FIFO. The CLEAR 
input is used to initialize Cind clear the FIFO. 
A Low level on this input clears all data from 
the FIFO, allows the EMPTY output to go High 
and forces both outputs RFD/DAVA and 
RFD/DAVB High. A High level on CLEAR 
allows the data to transfer through the FIFO. 


Bidirectional Transfer Control. The FIFO has 
bidirectional data transfer capability under 
control of the DIR AlB input. When DIR AlB is 
set Low, Port A becomes input handshake and 
Port B becomes output handshake; data 
transfers are then made from Port A t() Port B. 
Setting DIR AlB High reverses the handshake 
assignments and the direction of transfer. This 
bidirectional control is illustrated in Table 1. 


Port A 
Port B 
DIR AlB 
Handshake 
Handshake 
Transfer 


0 
Input 
Output 
A to B 


Output 
Input 
B to A 


Table 1. Bidirectional Control Function Tablo 


The FIFO buffer must be empty before the 
direction of transfer is changed; otherwise, the 
results of the change will be unpredictable. If 
FIFO status is unknown when a transfer direc- 


+5V 


tion change is to be made, the recommended 
procedure is: 


( 1) Force and hold CLEAR Low. 


(2) Set DIR AlB to the level required for the 
desired direction. 


(3) Force CLEAR High. 
Empty and Full Operation. The EMPTY and 
FULL output lines can be wire-ORed with the 
EMPTY and FULL lines of other FIFOs and 
FIOs. This capability enables the user to 
determine the empty/full status of a buffer con- 
sisting of multiple FIFOs, FIOs, or a combina- 
tion of both. Table 2 shows the various states of 
EMPTY and FULL. 


Number of 
Bytes in FIFO 
EMPTY 
FULL 


0 
High 
Low 


1-127 
Low 
Low 


128 
Low 
Higl} 


Table 2. Signals EMPTY and FULL Opo·ration Table 


Interconnection Example. Figure 6 illustrates 
a simplified block diagram showing the man- 
ner in which FIFOs can be interconnected to 
extend a FlO buffer. 


+5V 


FULL J-,_-----4--_--------l----1~---_.. 
SYSTEM FULL 


EMPTY ~------1~--+_-----_--+---I'----_.. 
SYSTEM EMPTY 


PORT 2 
of 
za03a 
zaooo 


DATA 
,, ___ 
I 
BUS 


zaooo 


RFD/DAYa J..--_ } 


~~~ASL~KE 


ACKINa _ 


OEa .--- OUTPUT CONTROL 


crEAR t-l---~-----+_-----.-...----I-----.. 
SYSTEM crEAR 


DATA DIR 1---l_------4--------------..I~---_.. SYSTEM DIRECTION 


Figure 6. Typical Interconnection (Simplified Diagram) 
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Maximum 
Ratings 


Standard 
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Conditions 
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Output Enable Operation. The FIFO provides 
a separate Out~ut Enable (OE) signal for each 
port of the buffer. An OE output is valid only 
when its port is in the Output Handshake 
mode. The control of this output function is 
shown in Table 3. Signal OE operates with 
lines DIR AlB. A High on a valid OE line 
3-states its port's data bus but does not affect 
the handshake operation. A Low level on a 
valid OE enables the data bus outputs if its 
. port is in the Output Handshake mode. Note 
that the handshake operation is unaffected by 
the Output Enable pin. 


Voltages on all inputs and outputs with respect 
to GND ................... -0.3 V to +7.0 V 
Operating 
Ambient Temperature ......... As speCified in 
Ordering Information 
Storage Temperature ......... -65° to + 150°C 


The characteristics below apply for the 
follOWing standard test conditions, unless 
otherwise noted. All voltages are referenced to 
GND. Positive current flows into the refer- 
enced pin. Standard conditions are as follows: 


+5V 


2.2K 


Figure 7. Standard Test Load 


DIR AlB 
OEA OEB 
Function 


o 
x 


o 
x 


o 


o 


X 


Disable Port A Output 
Enable Port B Output 


Disable Port A Output 
Disable Port B Output 


Enable Port A Output 
Disable Port B Output 


X 
Disable Port A Output 
Disable Port B Output 


NOTE: X = Don't care. 


Table 3. Output Control Function Table 


Stresses greater than those listed under Absolute Maximum 
Ratings may cause permanent damage to the device. This is a 
stress rating only; operation of the device at any condition above 
those indicated in the operational sections of these specifications is 
not implied. Exposure to absolute maximum rating conditions for 
extended periods may affect device reliability. 


• +4.75V:5Vcc :5 +5.25 V 


• GND = 0 V 
• TA as speCified in Ordering Information. All 
ac parameters assume a load capacitance of 
50 pF max. 


FRO~ OUTPUT 
UNDER TEST 


+5V d 


2•2K 


50 PFr 


Figure 8. Open-Drain Test Load 


8085-0239, 001 


DC 
Character- 
istics 


Capacitance 


Ordering 
Information 


Symbol 
Parameter 
Min 
Max 
Unit 


VIH 
Input High Voltage 
2.0 
Vcc+0.3 
V 


VIH 
Input Low Voltage 
-0.3 
0.8 
V 


VOH 
Output High Voltage 
2.4 
V 


VOL 
Output Low Voltage 
0.4 
V 


0.5 
V 


IlL 
Input Leakage 
±10 
p.A 


10L 
Output Leakage 
±10 
p.A 


Icc 
V cc Supply Current 
200 
rnA 


NOTE: VCC = +5 V ±5% unless otherwise specified over specified temperature range. 


Symbol 
Parameter 
Min 
Max 


CIN 
Input Capacitance 
10 


COUT 
Output Capacitance 
15 
Cvo 
Bidirectional Capacitance 
20 


Input 


tr 
Any input rise time 
100 


tf 
Any input fall time 
100 


NOTE: f = I MHz over specified temperature range. 


Unit 


pF 


pF 


pF 


ns 


ns 


Condition 


10H = -250 A 


IoL = +2.0 rnA 
IOL = +3.2 rnA 


0.4 :S VIN :S + 2.4 V 


0.4 :S VOUT :S +2.4 V 


Test Condition 


Unmeasured pins 


returned to ground 


Product 
Package/ 
Product 
Package/ 


Number 
Temp 
Speed 
Description 
Number 
Temp 
Speed 
Description 


28060 
CE 
4.0 MHz 
FIFO (28-pin) 
28060 
DS 
4.0 MHz 
FIFO (28-pln) 


28060 
CS 
4.0 MHz 
Same as above 
28060 
PE 
4.0 MHz 
Same as abovo 


28060 
DE 
4.0 MHz 
Same as above 
28060 
PS 
4.0 MHz 
Same as above 


NOTES: C = Ceramic, D = Cerdip, P = Plastic; E = -40°C to +85°C, S = O°C to 70°C 
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INPUT TIMING 
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W 
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OUTPUT ENABLE AND CLEAR 


CLEAR~-W-¥ 
INPUT 
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Figure 9. Timing Diagrams 
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FIFO 2-Wire Handshake Timing. Timing for 
2-wire interlocked handshake operation is 
shown in Figure 9. The symbol, description 


and values for the numbered parameters 
(Figure 9) are given in AC Characteristics. 


AC 
Character- 
istics 


00-2123-03 


No. 
Symbol 
Parameter 
Min 
Max 
Units· 


TsDI(ACK) 


2 
TdACKf(RFD) 


3 
TdRFDr(ACK) 


Data Input to ACKIN 1 to Setup Time 
ACKIN 1 to RFD 1 Delay 


RFD I to ACKIN 1 Delay 


50 
o 
o 
4 
TsDO(DAV) 
Data Out to DAV 1 Setup Time 
50 


5-TdDAVf(ACK)--DAV 1 to ACKIN 1 Delay -----------0----- 


6 
ThDO(ACK) 
Data Out to ACKIN I Hold Time 
50 


7 
TdACK(DAV) 
ACKIN 1 to DAV I Delay 
0 


8 
ThDI(RFD) 
Data Input to RFD 1 Hold Time 
0 


9 
TdRFDf(ACK) 
RFD 1 to ACKIN I Delay 
0 


10 -- TdACKr(RFD) -- ACKIN I to RFD I Delay 
0 ----- 


11 
TdDAVr(ACK) 
DAV I to ACKIN I 
0 


12 
TdACKr(DAV) 
ACKIN I to DAV 1 
o 


13 
TdACKINf(EMPTY) (Input) ACKIN 1 to EMPTY 1 Delay 


(Output) ACKIN 1 to EMPTY I Delay 


14 
TdACKINf(FULL) 
(Input) ACKIN 1 to FULL I Delay 
(Output) ACKIN 1 to FULL 1 Delay 


ns 


ns 


ns 
ns 
ns- 


ns 
ns 
ns 


ns 
ns- 


ns 


ns 


15 -- ACKIN Clock Rate (Input or Output) ----------------1.0--------- MHz- 


16 
TdACKINf(DAVf) . (Bubble Time) 


17 
TwCLR 
Width of Clear to Reset FIFO 


18 
TdOE(DO) 
OE 1 to Data Bus Driven 


19 
TdOE(DRZ) 
OE I to Data Bus Float 


NOTES: 
• All timing references assume 2.0 V for a logic 1 and 0.8 V for a 
logic O. Timings are preliminary and subject to change. 


700 
o 


ns 


ns 


n3 


ns 
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Features 


General 
Description 


1!!1 Detects errors in serial data up to 585,442 
bi ts in length 


II Implements correction of a detected error 
burst of up to 12 bits in length 


1I Handles effective data rates of up to 20M 


bits per second 


B Provides four industry-standard polynomials 
for error detection 


II Designed for use in both microprocessor 
and microprogrammed disk-controlled 
systems 


The 28065 Burst Error Processor (BEP) pro- 
vides error detection and correction facilities 
for high-performance, high-density disk 
systems and any other system in which high- 
speed serial data transfers occur. 
For error detection, the BEP provides a 
selection of four standard polynomials, 
including the more popular 56-bit and 4~-bit 


Do 
00 


01 
01 


02 
02 
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03 
03 I 
DATA DUT- 
INPUT 
04 
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05 
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m Provides three correction algorithms: 
o Full-period clock-around method for con- 
formance to current practices 
o Chinese remainder theorem, which 
reduces correction time by orders of 
magnitude 
o Reciprocal polynomial, which allows cor- 
rection with 48-bit code 


versions, to satisfy a broad range of applica- 
tions. During write operations, the BEP 
,generates check-bit words, which are append- 
ed to the record being written onto the disk. 
These check-bit words are then used in subse- 
quent reads and, if necessary, in correction 
operations. 
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Figure 1. Pin Functions 
Figure 2. Pin Assignments 
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When a stored record is read, the BEP com- 
putes the syndrome for data validation. This 
syndrome is then used to determine' if an error 
burst is present in the retrieved data stream. If 
an error is detected, the BEP can be used to 
locate its actual bit pattern. The information 
obtained is then made available to the host 
system where it is used to correct the data 
read. Any of the three algorithms can be 


AE. Alignment Exception (output, active 
High). This output goes High when a misalign- 
ment condition occurs during an error-pattern 
search operation. 


Co-~. Function Select (inputs, active High). 
These three lines carry the binary code used to 
select the BEP functions. The codes and the 
functions initiated by each are listed in 
Table 1. 


~ Cl 
Co 
Function 


L 
L 
L 
Compute Check Bits 


L 
L 
H 
Write Check Bits 


L 
H 
L 
Read Normal 


L 
H 
H 
Read High Speed 


H 
L 
L 
Load 


H 
L 
H 
Reserved 


H 
H 
L 
Correct Normal (Full Period 
Clock Around) 


H 
H 
H 
Correct High Speed (Chinese 
Remainder Theorem Method) 


H = High, L = Low 


Table 1. Function Sel~ct Codes 


CPo Clock (input, active High). All BEP 
operations are timed by this external clock 
input. Any input changes must be made to the 
BEP v:hen CP is High. Data is strobed into the 
BEP only during the Low-to-High transition of 
CP. BEP outputs are valid only after a subse- 
quent Low-to-High transition occurs on CP. 
Do-D7. Data In (input, active High). These 
eight lines are used to enter data into the BEP. 
Do is the least-significant bit (LSB) position of 
the input; D7 is the most-significant bit (MSB) 
position of the input. Data entry occurs on the 
Low-to-High transition of the input clock pulse. 
Any change on Do-D7 must take place when 
the clock pulse (CP) input is High. 


EP. Error Pattern (output, active High). Dur- 
ing an error correction process, EP is set High 
to indicate that the bit pattern of the detected 
error has been found. EP is set Low each time 
the BEP is initialized. EP is valid only during 
the performance of a correction function; it 
must be ignored at all other times. 


ER. Error (output, active High). ER indicates 
that the BEP has detected an error in the input 


selected for this process. 
The BEP is fabricated using silicon-gate, 


N-MOS technology and is supplied in a 40-pin 
dual in-line package (DIP). Figures 1 
and 2 illustrate the pin functions and pin 
assignments, respectively, of the Z8065. Z8065 
operation requires a + 5 V dc power supply 
and a single-phase clock. 


data stream. If the register array contains a 
zero syndrome, ER is set Low to indicate that 
no error was detected. If the array contains a 
non-zero syndrome, ER is set High to indicate 
that an error was detected. The output is valid 
only after the BEP receives the last check byte 
during a normal read or a read high-speed 
function. The resulting syndrome is contained 
by the register array. ER is set Low each time 
the BEP is initialized. 


LPO-LP3. Located Error Pattern (outputs, 
3-state). These four lines, together with QO-Q7 
provide a 12-bit error pattern that is output 
when REP is High. Q7 is the MSB of the pat- 
tern; LPO is the LSB of the pattern. A High 
level on any output line represents a logical 1; 
a Low level a logical O. When no error pattern 
is available (REP is Low), output lines LPO-LP3 
and QO-Q7 are maintained in a high- 
impedance state. 


MR. Master Reset (input, active Low). This 
input controls the initialization of the BEP. Set- 
ting MR Low for a minimum period of 800 ns 
initialized the BEP. The BEP must be initialized 
prior to performing compute check bits, read 
normal, read high-speed, and load functions. 


PO-P3. Polynomial Shift Control (inputs, active 
High). During correction procedures using the 
Chinese remainder theorem, each syndrome 
obtained by the high-speed read function is 
shifted individually. The PO-P3 inputs provide 
this capability: Po enables the shifting of the 
first syndrome, PI shifts the second syndrome 
and so on. A High on an input allows the cor- 
responding register to shift; a Low causes it to 
hold. These inputs are effective only during 
the correct high-speed function. Changes on 
these inputs occur only when the CP input is 
High. 


PM2-PM4. Pattern Match (outputs, active 
High). These lines are used during a Chinese 
remainder theorem error-correction operation 
to indicate error-pattern match conditions for 
each syndrome involved. When High, an out- 
put speCifies that the corresponding syndrome 
register has achieved a match. 


QO-Q7. Data Out (outputs, 3-state). These 
eight lines are active only during write check 
bit and error correction functions. At all other 
times, QO-Q7 are maintained at a high- 
impedance level. During the write check bit 
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function, check bits are presented to these 
lines one byte at a time. Qo is the LSB and Q7 
is the MSB of the output. During the error- 
correction function, REP enables these lines to 
carry the detected error bit pattern. 


REP. Read Error Pattern (input, 3-state). REP 
when High, enables lines LPO-LP3 and QO-Q7. 
This error pattern information is valid only 


after a High is indicated on the EP output dur- 
ing correction operations. 


SO-SI. Polynomial Select (inputs, active High). 
These two pins carry the binary codes required 
to select which polynomial the BEP will imple- 
ment. The select codes (logic levels) are given 
in Table 2. 


Polynomial 
Number of 
Check Bits 


L L 
(X22 + l)(XlI +X7 +X6-i-X+ 1)(X12+XlI +XlO+X9+X8+X7 +X6+X5+X4+X3+X2+X+ 1) 
(XlI +X9+X7 +X6+X5+X+ 1) 


L H 
(X21 + l)(XlI + X2 + 1) 


H L 
(X23 + 1)(X12+XlI +X8+X7 +X3+X+ 1) 


H H 
(X13+ 1)(X35+X23+X8+X2+ 1) 


H = High, L = Low 


56 


32 


35 


48 


Table 2. Polynomial Select Codes 


The BEP consists of four major circuit 
groups: control logic, polynomial divide 
matrix, register array, and status logic. Figure 
3 shows a block diagram of the BEP. 


Control Logic. The control logic circuits pro- 
vide timing, reset, polynoinialselection, and 
read error-pattern control inputs for the 
remaining BEP circuits. 
Basic timing is provided to the control logic 
by clock input CPo The control logic generates 
and distributes appropriate timing and control 
signals to the remaining BEP circuits. 
Enabling the Master Reset (MR) causes the 
control logic to initialize all device circuits. 
This operation is usually performed before the 
execution of a selected device function. 
Function select and polynomial select inputs 


RESET (MA) ---------, 


CLOCK (CP) -----, 


are decoded by the control logic. The outputs 
of the decoder are then used to generate the 
control and timing signals needed to perform 
the encoded function or to select the encoded 
pol ynomial. 
The Read Error Pattern (REP) and 


Polynomial Shift Control signals enable the 
control logic to strobe valid error bit pattern 
outputs onto the register array output lines. 
During high-speed corrections, the polynomial· 
shift inputs are used for register array, error 
burst-pattern bit-matching operations. 
Polynomial Divide Matrix. This matrix con- 
nects the register array circuits so that each 
data byte presented on lines Do-D7 is suitably 
divided by the user-selected polynomial. The 
connections to be made are determined by 


STATUS LOGIC 


ZERO DETECTION 
t---. ERROR (ERI 


ALIGNMENT MONITOR 
t---. ALIGNMENT EXCEPTION (AE) 


ERROR PATTERN DETECTOR 
t---. ERROR PATTERN (EP) 


FUNCTION 


SELECT (C2-CO) 


POLYNOMIAL SHIFT 
CONTROL (P3-PO) '--__ 
" 


POLYNOMIAL 


SELECT (5,-50) 


L.-___ 
~o::------....Jr-----v PATTERN MATCH (PM.·PM2) 


REGISTER 
ARRAY 


POLYNOMIAL 
DIVIDE MATRIX 


1-_____ ,\ DATA OUT 
1-_____ ,/ (07-00) 


Figure 3. Simplified Block Diagram 
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gating the signals supplied by the control logic 
after decoding the select code on inputs So 
andSl. 
Register Array. This array consists of 56 flip- 
flop circuits used for: (1) check-bit computa- 
tion during write operations, (2) syndrome 
computation during read operations, and (3) 
error pattern extraction during error- 
correction operations. 
The bit patterns required for array functions 
are provided by the polynomial divide matrix. 
The array and matrix circuits, together, 
simulate a serial, polynomial, feedback-shift 


Condition 
Detected 


register arrangement in an 8-bit parallel form. 
At the end of each write operation, the com- 
puted check-bit bytes are available on lines 
00-07. On completion of a correction opera- 
tion, the bit pattern of the detected error is 
available on lines LPO-LP3 and 00-07. Input 
REP determines when a valid error bit pattern 
is on the register output lines. 


Status Logic. These circuits monitor the 
register array to detect the conditions listed in 
Table 3 and to enable the generation of the 
corresponding control signals. 


Signal 


Result of Polynominal Division 
ER (error) High when error found; Low when no error. 


Alignment during H-S and normal correction 


Location of an error bit pattern 


AE (alignment error) High when error pattern is incorrectly aligned. 


EP (error pattern) High when an error-bit pattern is detected. 


Pattern matching during H-S correction 
PM2, PM3, PM4 (pattern match). Each signal goes High when its 
corresponding register matches the proper section of a located burst·bit 
pattern. 


Table 3. Status Logic. Detected Condition and Resulting Output 


The BEP detects and corrects data errors 
using write, read, and correct operations. The 
BEP operates in conjunction with external 
logic: either a microprocessor or micropro- 
grammed control circuitry. Master clock 
inputs, the selection of polynomials and func- 
tions, and the output of check bytes and error 
bit patterns are initiated and controlled by 
inputs from external circuits. External logic is 
also used to collect data, perform calculations, 
and carry out the actual modification of stored 
data during error-correction operations. 
The BEP contains code for four standard 
polynomials (sometimes referred to as Fire 
codes). This code forms the basis fo the unit's 
error detection and correction functions. The 
polynomial to be used is selected by a coded 
input from the host system*. Table 2 lists the 
polynomial select codes, the equations imple- 
mented, and the number of check bits 
generated by each polynomial during a write 
operation. The same polynomial must be 
selected for the write, read, and correction 
operations performed for a given data stream. 
It is the responsibility of the host system to 
keep track of which polynomial is selected for 
use with each data stream. 
The BEP also contains the cod~ required to 
implement each of seven functions that can be 
executed during data stream write, read, and 
correction operations. The function to be per- 
formed is selected by a coded input from the 
host system. * The functions and their required 
input code are listed in Table 1. 


'NOTE: In the remainder of this specification, external circuitry 
and software is referred to as the host system. 


Write Operation. Before data is written onto a 
disk or similar storage device, the BEP must 
generate and add check-bit bytes to the data to 
be stored. These bytes are required for the 
detection and correction of errors that may 
occur during write and during subsequent 
read operations. 
Immediately before a write operation, the 
host system must output codes to the BEP to 
select the polynomial to be used and to initiate 
the compute check-bit function. 
The data stream to be written is entered, on- 
the-fly, into the BEP as it is written onto the 
disk. Data is presented to the BEP as a series 
of 8-bit bytes in parallel form. Check bits are 
generated by dividing each input byte by the 
selected polynomial using the rules of algebra 
in polynomial fields. The check bits are stored 
as they are generated. Check bits are 
generated in sets of 56, 48, 35, or 32 bits, 
depending on the selected polynomial. When 
the last input byte has been processed, the 
write check-bit function is initiated by the host 
system. During a check-bit write, the 
generated check bits are organized into 8-bit 
bytes (check-bit bytes), which are output byte 
by byte in 8-bit parallel form on lines 00-07. 
The host system adds these check-bit bytes to 
the end of the newly written file. 
The polynomial selected for data write 
operations must also be used in subsequent 
reads of the written data. Therefore, in selec- 
ting a polynomial for a write operation, the 
user should consider the type of read and cor- 
rection functions desired for future data 
retrieval operations. The relationships between 


Functional 
Description 
(Continued) 


the polynomials and the read and corrections 
functions are: 


II A read normal function must be followed by 
a correct normal function. All four 
polynomials can be used with this set of 
read/correction functions. 


II A read high-speed function must be fol- 
lowed by the Chinese remainder theorem 
correction function. All but the 48-bit 
polynomial can be used with this set of 
read/ correction functions. 
Read Operations. When data is read from a 
disk, the BEP checks the retrieved data and 
check-bit bytes for read and write errors. If 
errors are detected, the host system initiates 
correction functions, retrieving from the BEP 
the information needed to locate and correct 
the erroneous data. Immediately before star- 
ting the read operation, the host system selects 
the desired polynomial and either a read nor- 
mal or a read high-speed function. Data and 
associated check-bit bytes are then loaded, 
byte-by-byte, into the BEP as they are read 
from the disk. A divide operation results in 
one or more syndromes (depending on the 
polynomial used), which are stored in the 
register arr-ay. The binary values of these syn- 
dromes indicate whether or not an error was 
present in the scanned data stream. If an error 
was detected, ER is set High. 
When an error condition is indicated and 
correction is desired, the host system must 
initiate a correct normal, a A8-bit correct nor- 
mal, or a correct high-speed function. The 
function selected depends on which 
polynomial and which read function were 
selected for the initial read operation. When 
executed, the selected correction function sup- 
plies the host system with the information 
needed to calculate the location of the error 
pattern in the data stream and to correct the 
erroneous data stream bits. 
Read Normal Function. When this function is 
selected, the polynomial matrix is configured 
to 'establish the selected polynomial in its 
expanded form. The input stream, data and 
check bit bytes, are divided byte by byte by 
the expanded polynomial. The results form a 
syndrome whose binary value is detected by 
the status logic. If the syndrome is nonzero, ER 
goes High, to indicate an error condition; if 
the syndrome is zero, ER remains Low, to 
indicate a no-error state. 
Read High-Speed Function. This function is 
selected when the correct high-speed function 
is used. All but the 48-bit polynomial can be 
used with this function. 


When selected, this function configures the 


polyncmial matrix to simultaneously divide 
each byte of the input data/check-bit stream by 
all factors .of the selected polynomial. The 
result of each factor division forms a separate 
syndrome. Thus, the number of syndromes 
developed depends upon the number of factors 
in the selected polynomial. The status logic 
monitors all syndromes and uses their com- 
bined binary values to determine if an error 
condition is present. If all syndromes are zero 
after the last byte of the input stream is read, a 
no-error state is indicated and ER remains 
Low. If any syndrome has a non-zero value, an 
error condition is indicated and ER is set High. 


48-Bit Polynomial. Only read normal and cor- 
rect normal functions can be used when this 
polynomial is .selected. The read normal func- 
tion for the 48-bit polynomial is performed in 
the same manner as for the other polynomials. 
The resulting syndrome, however, will be too 
long and cannot be used directly in subse- 
quent correct normal functions; instead, the 
reciprocal of the syndrome must be established 
in the BEP before the correct normal function 
is selected. The host system initiates this 
operation by selecting the write check-bit 
function immediately after the syndrome is 
formed and error is indicated. Clock pulses 
are then applied to the BEP during the write 
bit function to strobe the syndrome onto lines 
QO-Q7 as six sequential 8-bit bytes. The host 
system must then reverse the order of the syn- 
drome bits (that is, the original LSB becomes 
the new MSB and the original MSB becomes 
the new LSB) to form the reciprocal. The host 
system then reloads this new syndrome into the 
BEP by selecting the load function. 
Load Function. This function is used only dur- 
ing read normal and correct normal operations 
when the 48-bit polynomial is selected. The 
host system selects the load function to prepare 
the BEP to receive an externally-formed 
reciprocal syndrome and to control the loading 
of the syndrome bytes into the BEP. The load 
function causes the register array to be con- 
figured into an 8-bit wide, 7-bit deep shift 
register connected to lines Do-D7. The host 
system then presents the six syndrome bytes on 
lines Do-D7. Clock pulses are then generated 
to strobe the bytes into the Shift register one at 
a time. 
When all six bytes of the syndrome are 
loaded, the host system causes the input lines 
to be pulled Low, then generates a seventh 
clock pulse. The seventh clock pulse strobes 
these Lows into the Shift register as a zero 
dummy fill byte. On completion of the load 
operation, the BEP is ready for the cor!ect nor- 
mal function. 
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The detection of an error in a retrieved data 
stream causes the following corrective func- 
tions to be performed: 


1. The error burst containing the erroneous 
data bits is located by the BEP. 


2. Using data supplied by the BEP, the host 
system calculates the exact position of the 
error burst in the retrieved data stream. 
3. The bit pattern of the error burst is strobed 
out of the BEP and used by the host system 
to perform bit correction. 
Location of an Error Pattern. An error pat- 
tern is characterized by the appearance of a 
known number of consecutive Os in specific 
registers of the register array. The exact 
number of Os and their locations in the register 
array is unique to each polynomial. When a 
polynomial is selected for read and error- 
detect/correction operations, the pattern 
associated with that polynomial is loaded into 
the status logic. The status logic uses this pat- 
tern to identify an error burst during the error 
pattern location operations. 
When only one syndrome is developed dur- 
ing the read error-detection function, the 
error-bit pattern is located by repeatedly 
dividing the syndrome by the polynomial. Divi- 
sion is accomplished by the repeated applica- 
tion of clock pulses (CP), while ignoring the 
states of lines Do-D7. This operation results in 
a serial bit-by-bit reconstruction of the 
retrieved data stream. The generated data bits 
are shifted at a rate of one per clock cycle 
through the register array. The BEP status 
logic performs the actual error bit pattern 
detection as the data stream is reconstructed. 
The status logic monitors specific registers of 
the register array, and it detects a pattern of Os 
that matches the zero error pattern unique to 
the selected polynomial, it sets EP High to in- 
dicate that an error burst was found. 
When more than one syndrome is developed 
during the read error-detection function, each 


Polynomial 


(X22 + 1)(Xll +X7 +X6+X+ I)(XI2+Xll +XlO+ ... 
+X+ 1)(Xll +X9+X7 +X6+X5+X+ 1) 


(X21 + 1)(Xll +X2+ 1) 


(X23 + I)(XI2 +Xll + X8+ X7 + X3 + X + 1) 


(XI3+ 1)(X35+X23+x8+X2+ 1) 


syndrome is divided by its associated factor 
until a match condition is found for each. Each 
time a match is found, the status logic enables 
one of outputs PM2, PM3 or PMt. When the 
total error bit pattern is found, the status logic 
ou tpu ts associated with the syndromes of a 
polynomial (2 or 4) are all enabled. The clock 
pulses required for each factor syndrome 
divide operation are supplied by lines PO-P3. 


A major factor in calculating the exact loca- 
tion of error-burst patterns in the retrieved 
data stream is the number of clock pulses used 
by the BEP to detect the error-burst pattern. 
The host system must record the total number 
of clock pulses generated from the start of BEP 
pattern-location operations to the enabling of 
output EP. If necessary, this total must include 
the clock pulses needed for alignment 
operations. 


Bit Alignment. During syndromE;l division, the 
register array is configured into a matrix 
representing an 8-bit, parallel mechanization 
of a serial, polynomial division scheme. Under 
certain conditions the error pattern bits 


~eveloped do not line up automatically. When 
the status logic detects such a misalignment, 
AE is set High. When AE is High, the BEP 
switches internally into One-Bit Shift mode 
during which each input clock pulse shifts the 
data stream one cell through the register 
array. When alignment is achieved, the status 
logic sets AE Low and the BEP is switched out 
of the One-Bit Shift mode. The number of shift 
pulses needed to achieve alignment is an addi- 
tional factor in calculating the position of the 
error-bit pattern. 


Uncorrectable Errors. If the total clock cycle 
time needed to locate the error burst pattern is 
greater than the natural period of the selected 
polynomial (Table 4), an uncorrectable error 
condition is indicated and the host system must 
abort the correction operation. 


Correctable 
No. of 
Period 
Burst Error 
Check Bits 
(Bits) 
Length (Bits) 


56 
585,442 
11 


32 
42,987 
11 


35 
94,185 
12 


48 
13(235 _1) 
7 


Table 4. Polynomials, Checkbits. Natural Period. and Length of Error Burst 
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Correct Normal Function. This function must 
be preceded by a read normal function. With 
the exception of 4S-bit polynomial operations, 
this function performs all operations needed to 
construct a serial form of the retrieved data 
stream and to locate the detected error burst. 
The operations performed are the same as 
those described previously for a single- 
syndrome situation. 


Computing Error Bit Pattern Locations. If no 
alignment exception state is indicated (AE is 
Low), the locations of the error-bit pattern 
within the data stream (except when the 35-bit 
polynomial is used) can be calculated by the 
formula: 


L = NK - 
SRI 


Where: 


L = The location (number) of the first bit in 
the error burst, counting from the last check 
bit in the scanned record. 
. 


N = The natural period of the selected poly- 
nomial. 


K = The smallest integer needed to make this 
expression positive. 


RI = The total number of clock pulses input 
by the BEP from the start of the find operation 
until EP goes High. 
If an alignment exception state is indicated 
(AE is High), the location of the error-bit pat- 
tern within the data stream (except when the 
35-bit polynomial is used) can be calculated 
using the formula: 


L = NK - 
SRI - 
R2 


Where: 


L,N,K, and RI are the same as described 
above. 


R2 = The number of clock pulses input by the 
BEP between the time that AE goes High and 
EP goes High. 
If the 35-bit polynomial is selected, the 
quantity 5 must be added in the following man- 
ner to the formulas used to calculate the loca- 
tion of the error-bit pattern: 


L = NK - 
SRI + 5 
and L = NK - 
SR I - 
R2 + 5 


Correct Normal Function, 48-Bit Poly- 
nomial. The functions performed by the cor- 
rect normal function when a 4S-bIt polynomial 
is selected are essentially the same as those 
described for the other polynomials. The major 
exception is that the location 'of the first bit in 
the error-bit pattern is calculated using the 
formula: 


L = (SRI + R2) - 
4S 


Where: 


L = The number of bit positions from the last 
check bit to the nearest error burst bit. 


!--L __ I 


-1r--E-R-RO-R-B-UR-ST--'~ _ 
r-----, 


RI = If alignment is needed, RI is the number 
of clock pulses from the start of the find opera- 
tion until AE goes High. If no alignment is 
needed, R I is the total number of clock pulses 
from the start of the find operation until EP 
goes High. 


R2 = Variable used only when an alignment is 
needed; it represents the number of clock 
pulses from the time AE goes High until EP 
goes High. 
Correct High Speed Function. This function 
uses a Chinese remainder theorem to locate a 
detected error-burst bit pattern. This theorem 
minimizes the number of clock pulses required 
for the location process, thus making it appre- 
ciably faster than the correct normal method. 
The correct high-speed function must be 
preceded by the read high-speed function. The 
multiple syndromes developed during the read 
operation are located in consecutive sets'of 
flip-flops in the register array. The set of flip- 
flops containing syndromes is treated as an' 
individual shift register. Each syndrome shift 
register is associated with the factor of the 
polynomial used to develop the syndrome. For 
example, the 56-bit polynomial has four factors 
(see Table 2), and when selected for read and 
correction operations it causes four correspon- 
ding syndromes to be developed, each housed 
in an individual shift register in the register 
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The actual location of an error-bit pattern 
can be computed by the host system using the 
following elements: 


1. The number of clock pulses required (per 
factor/syndrome register) to find the error 
pattern. 


2. The natural period of each factor of the 
selected polynomial. 
3. A predetermined constant per factor. 


The formulas used to calculate error-pattern 
locations for high-speed operations are 
described in Table 5. Table 6 lists the pre~ 
determined constants for each factor of the 
polynomials. Table 7 lists the natural period of 
each factor of each polynomial. 


56-Bit L = (NK) - (AIMI + A2M2 + 
A3M3 + A4M4) 


·32-Bit L = (NK) - (AIMI + A2M2) 


35-Bit L = (NK) -(AIMI + A2M2 + 5) 


Table 5. Correct High-Speed. Error-Burst 
Location Formulas 


Legend: 


L = Beginning (first bit) of detected error 
burst counting from the last check bit in the 
processed record. 


-1 ERROR BURST ~- 


K = Smallest integer required to make right 
side of equation positive. 
AI-Al. = Predetermined constants for each 
factor of the selected polynomial. 


N = Natural period of selected polynomial. 


Ml-~ = Number of clock pulses required to 
achieve a match in each factor/syndrome 
register. 


A detected error-bit pattern can be strobed 
from the BEP in 12-bit, parallel form by for- 
cing REP High when EP goes High. The 12-bit 
output is then matched bit for bit with the cor- 
responding bits in the stored data. The error- 
bit pattern is then XORedwith the matching 
data stream bits to effect the required bit-by- 
bit correction. 
Figure 4 illustrates the format for strobing 
the error bit pattern (11 or 12 bits) out of the 
BEP in all but the 48-bit polynomial correction 
operation and shows how the pattern must be 
oriented to the data stream bits. Figure 5 illus- 
trates the format for strobing the error-bit pat- 
tern (7 bits) out of the BEP in the 48-bit 
polynomial correction operation and shows 
how the pattern must be oriented to the data 
stream bits. 
Data Stream Correction Function. Each 
detected error pattern consists of 12 con- 
secutive bits not all of which represent errors. 
If the data and check-bit stream scanned dur- 
ing the preceding read operation was stored in 
accessible memory, the error-bit pattern can 
be used directly to correct the data stream. 


Poly- 
Predetermined Constants 
nomial 
Al 
A2 
Aa 
A. 


56 Bit 
452,387 
2,521,404 578,864 
2,647,216 


32 Bit 
311,144 
32,760 


35 Bit 
32,760 
720,728 


Table 6. Chinese Romainder Theorem Coefficients 


Correction 
Operations 
( Continued) 


2078-003 
2078-004 


Tablo 7. Natural Periods for Polynomials and Polynomial Factors 


Period 
Period 
Period 
Period 
Composite 
Polynomial 
Factor I 
Factor 2 
Factor 3 
Factor 4 
Period (n) 


56 Bit 
22 
13 
89 
23 
585442 
32 Bit 
21 
2047 
42987 
35 Bit 
23 
4095 
94185 


L (COMPUTED ERROR LOCATION) 


RECORD 


DATA 


Figure 4. Error Pattern Fo.mat for 56-Bit. 35-Bit. and 32-Bit Polynomials 


Figure 5. Error Pattern Format for 48-Bit Polynomial 
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The overall timing requirements for BEP 
operations are illustrated in Figures 6 through 
13. Individual timing parameters are identified 
numerically in each timing diagram and are 
described in the AC Characteristics section. 


Figure 6. Clock Waveform For All Functions Except 
Correct Normal Or Correct High-Speed 


Min 
Max 
No. 
Symbol 
Parameter 
(ns) 
(ns) 


1 
TwCPl 
Clock Pulse (CP) Width (Low) 
180 


2 
TcCP 
Clock Pulse Cycle Time 
400 


3 
TwCPh 
Clock Pulse Width (High) 
180 


4 
TwMRI 
MR Pulse Width (Low) 
800 
5- TdMR(CP) -- MR t to CP l Time Delay-Recovery 
250 


6 
TsDI(CP) 
DI (Do-~) to CP t Setup Time 
350 


7 
ThCP(DI) 
CP t to DI (Do-~) Hold Time 
0 


8 
TsC(CP) or 
C(Co-C2) or S(SO-S1) to CP t 8etup Time 
400 
Ts8(CP) 


9 
ThCP(C) or 
CP t to C(CO-C2) or 8(80-81) Hold Time 
0 
ThCP(8) 
lO-TsC(CP) or-- C(CO-C2) or 8(So-81) to CP l 8etup Time 
180 
Ts8(CP) 


11 
TdC(Q) or 
C(CO-C2) or S(80-82) to Q(Qo-~) Valid Time Delay 
200 


Td8(Q) 
12 
TdCP(Q) 
CP t to Q(Qo-~) Invalid Time Delay 
0 


13 
TdCP(Q) 
CP t to Q(Qo-~) Valid Time Delay (write) 
200 


14 
TdC(Q) 
C(CO-C2) to Q(QO-Q7) Time Delay-3-state 
100 


15 - 
TdMR(ER) -- MR l to ER l Time Delay 
200- 


16 
TdCP(ER) 
CP t to ER t Valid Time Delay 
200 


17 
TwCPCl . 
CP Pulse Width (Low) for Correct Functions 
450 


18 
TwCPCh 
CP Pulse Width (High) for Correct Functions 
450 


19 
TcCPC 
CP Cycle Time for Correct Functions 
1000 
20- TdC(EP) 9r-- C(CO-C2) to EP or to AE Valid Time Delay 
250- 
TdC(AE) 


21 
TdCP(EP) or 
CP l to EP, to AE or to PM(PM2-PM4) Valid Time Delay 
400 
TdCP(AE) 


22 
TsP(CP) 
P(PO-P3) to CP l Setup Time 
400 


23 
TdPo(EP) or 
Po t to EP or to AE Time Delay 
250 
TdPo(AE) 


24 
TsC(CPC) or 
C(CO-C2) or 8(80-81) to CP l 8etup Time for Correct Functions 
400 
Ts8(CPC} 


25 - 
TdP(PM) --- P1 or P2 or P3 to Corresponding PM Output, Time Delay 
250- 


26 
TdCP(EP) or 
CP l to EP, to AE, or to PM (PM2, PM3, P~) Invalid Time Delay 
0 
TdCP(AE) or 
TdCP(PM) 


27 
TdPo(EP) or 
Po l to EP or to AE Invalid Time Delay 
0 
TdPo(AE) 


28 
TwREPh 
REP Pulse Width (High) 
250 


29 
TdREP(Q) or 
REP t to Q(Qo-~) or to LP(LPo-LP3) Time Delay 
150 
TdREP(LP) 
30- TdREP(QT) or- REP l to Q(Qo-~) or to LP(LPo-LP3) Time Delay 3-state 
100- 
TdREP(LPT) 


31 
TdP(PM) 
P(P1-P3) l to PM(PM2-P~) Invalid Time Delay 
0 


32 
TdC(EP) or 
C(CO-C2) to EP, or to AE, PM(PM2-P~) Invalid Time Delay 
0 
TdC(AE) or 
TdC(PM) 


* All timings are preliminary and subject to change. 
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2078·006 2078·007 2078-008 


CP 


Figure 7. Compute Check Bits or Load Function 


f-----@---~ 


Notes: 1. REP input assumed low. 


2. 0 0.07 outputs will be high impedance if CO-C2 inputs do not specify write check bits function. 


Figure 8. Write Check Bits Function 


I--t---@ 


Note: ER output is a function of the contents in the register array flip·f1ops. 


Figure 9. Read Normal or Read High-Speed Function 
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Figure 10. Clock Waveform for Correct Normal or Correct High-Speed Functions 
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Note 1: Assumes AE or EP output becomes active without any clocking. 


Figure II. Correct Normal Function 
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Note 2 


~----------~~~~--------~~ 


EP,AE 


Note 3 


Note 2: Assumes EP, AE becomes active without clocking. 
Note 3: Assumes corresponding PM output becomes active without clocking. 


Figure 12. Correct High-Speed Function 
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QO-Q7/LP_O_-_L_P_3 ________________ ~~--------------------~~ 


Figure 13. Read Error Pattern Timing 
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Electrical 
Character- 
istics 


Voltages on all inputs and outputs with respect 
to GND ................... -0.3 V to +7.0 V 
Operating 
Ambient 
Temperature ........ See Ordering Information 
Storage Temperature ......... -65° to + 150°C 


The characteristics below apply for the fol- 
lowing standard test conditions I unless other- 
wise noted. All voltages are referenced to 
GND. Positive current flows into the refer- 
enced pin. Standard conditions are as follows: 


[J +4.75 V ~ Vee ~ +5.25 V 


[J GND = 0 V 


[J O°C ~ TA ~ +70°C 


Symbol 


VeH 


VeL 


VlH 
VIL 
VOH 


VOL 


IlL 


10L 


Icc 


Symbol 


VIL 
VlH 


VOL 
VOH 


10L 


IWH 
CIN 
CliO 


ILL 


. Parameter 


Clock Input High Voltage 


Clock Input Low Voltage 


Input High Voltage 


Input Low Voltage 


Output High Voltage 


Output Low Voltage 


Input Leakage 


Output Leakage 


Vee Supply Current 


Parameter 


Input Low Voltage 


Input High Voltage 


Output Low Voltage 


Output High Voltage 


Output Leakage Current 


Output Leakage Current 


Input Capacitance 


I/O Capacitance 


Input Leakage Current 


Icc 
Vee Power Supply Current 


Min 


Vee-O.4 


-0.3 


2.0 


-0.3 


2.4 


Min 


-0.5 


2.0 


2.4 


Stresses greater than those listed under Absolute Max- 
imum Ratings may cause permanent damage to the device. 
This is a stress rating only; operation of the device at any 
condition aDove those indicated in the ~perational sections 
of these specifications is not implied. Exposure to absolute 
maximum rating conditions for extended periods may affect 
device reliability. 


Max 


Vee+ 0.3 


0.45 


Vee+ 0.3 


0.8 


0.4 


± 10 


± 10 


300 


Max 


+.8 


Vee 
0.4 


10 


10 


15 


25 


± 10 


Unit 
v 


V 


V 
V 
V 
V 


p.A 


p.A 
rnA 


Unit 


V 
V 
V 
V 


p.A 


p.A 
pF 
pF 


p.A 


+5V 


2.2K 


Condition 


Driven by external clock 
generator 


Driven by external clock 
generator 


10H = -250 A 


10L = +2.0 rnA 


0.4 :S VIN :S + 2.4 V 


0.4 :S VIN :S + 2.4 V 


Condition 


10H = 3.2 rnA 


10H = 400 p.A 


VOUT 
0.4 V 


VOUT 
Vee 


NOTE: Typical values apply at TA = 25°C and Vee = 5.0 V. See table above for operating range. 


Ordering 
Information 
Product 
Number 


Z8065 


Paclcage/ 


Temp 
Speed 


DS 
4.0 MHz 


Description 


Burst Error 
Processor 
(40-pin) 


NOTES: D = eerdip, P = Plastic, S = ooe to 70°C 
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Product 
Number 


Z8065 


Package/ 
Temp 
Speed 


PS 
4.0 MHz 


Description 


Burst Error 
Processor 
(40-pin) 
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Zilog 


Features 


General 
Description 


El Encrypts and decrypts data using the 
National Bureau of Standards encryption 
algorithm. 


c Supports three standard ciphering modes: 
Electronic Code Book, Chain Block and 
Cipher Feedback. 


lJ Three separate registers for encryption, 
decryption, and master keys improve system 


The Z8068 Data Ciphering Processor (DCP) 


is an n-channel, silicon-gate LSI device, which 
contains the circuitry to encrypt and decrypt 
data using National Bureau of Standards 
encryption algorithms. It is designed to be 
used in a variety of environments, including 
dedicated controllers, communication concen- 
trators, terminals, and peripheral task pro- 
cessors in general processor systems. 
The DCP provides a high throughput rate 
using Cipher Feedback, Electronic Code 
Book, or Cipher Block Chain operating modes. 
The provision of separate ports for key input, 
clear data, and enciphered data enhances 
security. 
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Figure 1. Pin Functions 
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security and throughput by eliminating fre- 
quent reloading of keys. 


B Three separate programmable ports (master, 
slave, and key data) provide hardware 
separation of encrypted data, clear data, 
and keys. 


IJ Data rates greater than 1M bytes per second 
can be handled. 


t:I Key parity check. 


The host system communicates with the DCP 


using commands entered in the master port or 
through auxiliary control lines. Once set up, 
data can flow through the DCP at high speeds 
because input, output and ciphering activities 
can be performed concurrently. External DMA 
control can easily be used to enhance 
throughput in some system configurations. 
The 28068 DCP is designed to interface 
directly to Zilog's Z-BUS® . Device signal/pin 
functions are shown in Figure 1; actual pin 
number assignments are shown in Figure 2. 
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Figure 2. Pin Assignments 
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Pin 
AFLG. Auxiliary Port Flag (output, active 
Descriptions 
Low). This output signal indicates that the DCP 
is expecting key data to be entered on pins 
AUXo-AUX7. This can occur only when C/K is 
Low and a \\Load Key Through AUX Port" 
command has been entered. AFLG remains 
active (Low) during the input of all eight bytes 
and will go inactive with the leading edge of 
the eighth strobe (ASTB). 


390 


ASTB. Auxiliary Port Strobe (input, active 
Low). In Multiplexed Control mode (C/K Low), 
the rising (trailing) edge of ASTB strobes the 
key data on pins AUXo-AUX7 into the 
appropriate internal key register. This input is 
ignored unless AFLG and C/K are both Low. 
One byte of key data is entered on each ASTB 
with the most significant byte entered first. 


AUXo-AUX7' Auxiliary Port Bus (bidirectional, 
active High). When the DCP is operated in 
Multiplexed Control mode (C/K Low), these 
eight lines form a key-byte input port, which 
can be used to enter the master and session 
keys. This port is the only path available for 
entering the master key. (Session keys can also 
be entered via the master port.) A UXo is the 
low-order bit and is considered to be the parity 
bit in key bytes. The most significant byte is 
entered first. 
When the DCP is operated in Direct Control 
mode (C/K High), the auxiliary port's key- 
entry function is disabled and five of the eight 
lines become direct control/status lines for 
interfacing to high-speed microprogrammed 
controllers. In this case, AUXo, AUXI and 
AUXt have no function, and the other pins are 
defined as follows: 
AUX2-BSY. Busy (output, active Low). This 
status output gives a hardware indication that 
the ciphering algorithm is in operation. 
AUX2-BSY is driven by the BSY bit in the 
Status register such that when the BSY bit is 1 
(active), AUX2-BSY is Low. 
AUX3-CP, CommandPending (output, active 
Low). This status output gives a hardware 
indication that the DCP is ready to accept the 
input of key bytes following a Low-to-High 
transition on AUX7-K/D. AUX;3-CP is driven 
by the CP bit in the Status register such that 
yrhen the CP bit is 1 (active), AUX3-CP is 
Low. 
AUXs-S/S. Start/Stop (input, Low = Stop). 
When this pin goes Low (Stop), the DCP 
follows the normal Stop command sequence. 
When this pin goes High, a sequence 
equivalent to a Start Encryption· or Start 
Decryption command is followed. When 
Auxs-sis goes High, the level on AU%-E/D 
selects either the start encryption or start 
decryption operation. 
AUXs-E/O. Encrypt/Decrypt (input, 
Low = Decrypt). When AUXs-S/S goes High, 


it initiates a normal data ciphering operation 
whose input specifies whether the ciphering. 
algorithm is to encrypt (E/D High) or decrypt 
(E/D Low). 
When AUX7-K/15 goes High, initiating the 
entry of key bytes, the level on AU%-E/D 
specifies whether the bytes are to be written 
into the E ·Key register (E/D High) or the D key 
Register (E/D Low). 
The AU%-E/D input is not latched internally 
and must be held constant whenever one or 
more of Auxs-S/s, AUX7-K/D, AUX2-BSY, or 
AUX3-CP are active. Failure to maintain the 
proper level on A U%-E/D during loading or 
ciphering operations results in scrambled data 
in the internal registers. 
AUX7-K/D. Key/Data (input, Low = Data). 
When this signal goes High, the DCP initiates 
a key-data input sequence as ifa Load Clear E 
0r D Key Through Master Port command had 
been entered. The level on AU%-E/D deter- 
mines whether the subsequently entered clear- 
key bytes are written into the E key register 
(E/D High) or the D key register (E/D Low) 


AUX7-K/D and AUXs-S/S are mut~ally 


exclusive control lines; when one goes active 
(High), the other must remain inactive (Low) 
until the first returns to an inactive state. In 
addition, both lines must be inactive (Low) 
whenever a transition occurs on C/K (entering 
or exiting Direct Control mode). 
C/K. Control/Key Mode Control. {input, 
Low = Key}. This input determines the 
operating characteristics of the DCP. A Low 
input on C/K puts the DCP into the Multiplex- 


. ed Control mode, enabling programmed 
access to internal registers through the master 
port and enabling input of keys through the 
master or auxiliary port. A High input on C/K 
specifies operation in Direct Control mode. In 
this mode, several of the aUXiliary porL pins 
become direct control status signals which can 
be driven/sensed by high-speed controller 
logiC, and access to internal registers through 
the master port is limited to the Input or Out- 
put register. 


CLK. Clock {input, TTL compatible}. An exter- 
nal timing source is input via the CLK pin. 
The Data Strobe signals (MDS, SDS) must 
change synchronously with this clock input, as 
must Master Port Address Strobe (MAS) in 
Multiplexed Control mode (CiK Low), and also 
AUX7-K/D and Auxs-sis in Direct Control 
mode (CiK High). In addition, the Auxiliary, 
Master and Slave Port Flag outputs (AFLG, 
MFLG, and SFLG) change synchronously with 
the clock. When using the DCP with the Z8000 
CPU in Multiplexed Control mode, the clock 
input must agree in frequency and phase with 
the processor clock; however, the DCP does 
not require the high voltage levels of the pro- 
cessor clock. 


Pin 
Descriptions 
(Continued) 


MAs. Master Port Address Strobe (input, 
active Low). In Multiplexed Control mode 
(C/K Low), an active (Low) signal on this pin 
indicates the presence of valid address and 
chip select information at the master port. This 
information is latched internally on the rising 
edge of Master Port Address Strobe (MAS). 
When C/K is High (Direct Control mode), 
MAS can be High or Low without affecting 
DCP operation, except that, regardless of the 
state of CIK, if both Master Port Address 
Strobe (MAS) and Data Strobe (MDS) are Low 
simultaneously, the DCP Mode register will be 
reset to ECB mode. The master port is 
assigned to clear data, the slave port is 
assigned to enable data, and all flags remain 
inactive. 


MCS. Master Port Chip Select (input, active 
High). This signal is used to select the master 
port. In Multiplexed Control mode (C/K Low), 
the level on MCS is latched internally on the 
rising edge of Master Port Address Strobe 
(MAS). This latched level is retained as long 
as MAS is High; when MAS is Low, the latch 
becomes invisible and the internal signal 
follows the MCS input. In Direct Control mode 
(C/K High), no latching of Master Port Chip 
Select occurs; the level on MCS is passed 
directly to the internal select circuitry, 
regardless of the state of Address Strobe 
(MAS). 


MDS. Master Port Data Strobe (input, active 
Low). When MDS is active and Master Port 
Chip Select (MCS) is valid, it indicates that 
valid data is present on MPa-MP7 during out- 
put. MDS and Master Port Address Strobe 
(MAS) are normally mutually exclusive; if both 
go Low simultaneously, the DCP is reset to 
ECB mode and all flag~ remain inactive. 


MFLG. Master Port Flag (output, active Low). 
This flag is used to indicate the need for a data 
transfer into or out of the master port during 
normal ciphering operation. Depending upon 
the control bits written to the Mode register, 
the master port is associated with either the 
Input register or the Output register. 
If data is to be transferred through the 
master port to the Input register, the MFLG 
. reflects the contents of the Input register; after 
any start command is entered, MFLG goes ac- 
tive (Low) whenever the Input register is not 
full. MFLG is forced High by any command 
other than a start. Conversely, if the master 
port is associated with the Output register, 
MFLG reflects the contents of the Output 
register (exc~pt in single-port configuration). 
MFLG goes active (Low) whenever the Output 
register is not empty. In single-port configura- 
tion, MFLG reflects the contents of the Input 
register, while the Slave Port Flag (SFLG) is 
associated with the Output register. 


MPO-MP7. Master Port Bus (input/output, 
active High). These eight bidirectional lines 
are used to specify internal register addresses 
in Multiplexed Control mode (see C/K) and to 
input and output data. The master port pro- 
vides software access to the Status, Command 
and Mode registers as well as the Input and 
Output registers. The 3-state master port out- 
puts are enabled only when the master port is 
selected by Master Port Chip Select CMCS) 
. 
being Low, with Master Port Read/Write 
(MR/W) High, and strobed by a Low on the 
Master Port Data Strobe (MDS). MPa is the 
low-order bit. Data and key information is 
entered into this port with most significant byte 
input first. 
MR/W. Master Port Read/Write (input, 
Low = Write). This signal indicates to the 
DCP whether the current master port operation 
is a read (MR/W is High) or a write (MR/W is 
Low), thereby indicating whether data is to be 
transferred from or to an internal register. 
MR/W is not latched internally and must be 
held stable while Master Port Data Strobe 
(MDS) is Low. 


PAR. Parity (output, active Low). The DCP 
checks all key bytes for correct (odd) pari ty as 
they are entered through either the master port 
(Multiplexed or Direct Control mode) or the 
auxiliary port (Multiplexed Control mode 
only). If any key byte contains even parity, the 
PAR bit in the Status register is set to 1 and 
PAR goes Low. The least significant bit of key 
bytes is the parity. 


SCS. Slave Pori Chip Select (input, active 
Low). This signal is logically combined with 
Slave Port Data Strobe (SDS) to facilitate slave 
port data transfers in a bus environment. SCS 
is not latched internally and can be per- 
manently tied to Low without impairing slave 
port operation. 


SDS. Slave Pori Data Strobe (input, active 
Low). When both SDS and SCS are Low, it 
indicates to the DCP either that valid data is 
on the SPa-SP7 lines for an input operation, or 
that data is to be driven onto the SPa-SP7 lines 
for output. The direction of data flow is deter- 
mined by the control bits in the Mode register . 


SFLG. Slave Pori Flag (output, active Low). 
This output indicates the status of either the 
Input'register or the Output register, depen- 
ding on the control bits in the Mode register. 
In single-port configuration, -SFLG goes active 
during normal processing whenever the Out- 
put register is not empty. In dual-port con- 
figuration, SFLG reflects the content of 
whichever register is associated with the slave 
port. If the input register is assigned to the 
slave port, SFLG goes active w4enever the 
Input register is not full, once any of the start 
commands has been entered; SFLG is forced 
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inactive if any other command is entered. If 
the slave port is assigned to the Output 
register, SFLG goes active whenever the Out- 
put register is not empty. In this case, SFLG 
goes inactive if any command is aborted. 


SPO-SP7. Slave Port Bus (bidirectional). The 
slave port provides a second data inpuVoutput 
interface to the DCP, allowing overlapped 


The overall design of the DCP, as shown 
in Figure 3', is optimized to achieve high data 
throughput. Data bytes can be transferred 
through both the master and slave ports, and 
key bytes can be written through both the aux- 
iliary and master ports. Three 8-bit buses 
(input, output and C bus) carry data and key 
bytes between the ports and the internal 
registers. Three 56-bit, write-only key registers 
are provided for the Master (M) Key, the 
Encryption (E) Key and the Decryption (D) 
Key. Parity checking is provided on incoming 
key bytes. Two 64-bit registers are provided 
for initializing vectors (lVE and IVD) that are 
required for chained (feedback) ciphering 
modes. Three 8-bit registers (Mode, Command 
and Status) are accessible through the master 
port. 
Algorithm Processing. 
The algorithm pro- 
cessing unit of the DCP (Figure 3) is designed 
to encrypt and decrypt data according to the 
National Bureau of Standards' Data Encryption 
Standard (DES), as specified in Federal Infor- 
mation Processing Standards Publication 46. 
The DES specifies a method for encrypting 
64-bit blocks of clear data ("plain text") into 
corresponding 64-bit blocks of "cipher text." 
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input, output, and ciphering operations. The 
3-state slave port outputs are driven only when 
Slave Port Chip Select (SCS) and Slave Port 
Data Strobe (SDS) are both Low, SFLG isO, 
and the internal port control configuration 
allows output to the slave port. SPa is the low 
order bit. The most significant byte of data 
blocks is entered or retrieved through this port 
first. 


The DCP offers three ciphering methods, 
selected by the cipher type field of the Mode 
register: Electrqnic Code Book (ECB), Cipher 
Block Chain (CBC) and Cipher Feedback 
(CFB). These niethods are implemented in 
accordance with Federal Information Process- 
ing Standards, Publication 46. 
Electronic Code Book (ECB) is a straightfor- 
ward implementation of the DES: 64 bits of 
clear data in, 64 bits of cipher text out, with no 
cryptographic dependence between blocks. 
Cipher Block Chain (CBC) also operates on 
blocks of 64 bits, but it includes a feedback 
step which chains consecutive blocks so that 
repetitive data in the plain text (such as ASCII 
blanks) does not yield repetitive cipher text. 
CBC also provides an error extension 
characteristic which protects against 
fraudulent data insertions and deletions. 
Cipher Feedback (CFB) is an additive 
stream cipher method in which the DES 
algorithm generates a pseudorandom binary 
stream, which is then exclusive-ORed with the 
clear data to form the Cipher text. The cipher 
text is then fed back to form a portion of the 
next DES input block. The DCP implements 
8-bit cipher feedback, with data input, output, 


Figure 3. Z8068 Block Diagram 
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and feedback paths of one byte wide. This 
method is useful for low speed, character-at-a- 
time, serial communications. 


Multiple Key Registers. The DCP provides 
the necessary registers to implement a 
multiple-key or master-key system. In such an 
arrangement, a single master key, stored in 
the DCP M key register, is used to encrypt ses- 
sionkeys for transmission to remote DES 
equipment and to decrypt session keys 
received from such equipment. The M Key 
register may be loaded (with plain text) only 
through the auxiliary port, using the Load 
Clear Master Key command. In addition to the 
M Key register, the DCP contains two session 
key registers: the E key register, used to en- 
crypt clear text, and the D key register, used 
to decrypt cipher text. All three registers are 
loaded by writing commands such as Load 
Clear E Key, through master port, into the 
Command. register, and then writing the eight 
bytes of key data to the port when the Com- 
mand Pending bit in the Status register is 1. 


Operating Modes: Multiplexed Control vs. 
Direct Control. The DCP can be operated in 
either of two basic interfacing modes, deter- 
mined by the logic level on the C/K input pin. 
In Multiplexed Control mode (C/K Low), the 
DCF is configured internally to allow a master 
CPU to address five of the internal con- 
trol/status/data registers directly, thereby con- 
trolling the· device via mode and command 
values written to these registers. Also, in this 
mode, the auxiliary port is enabled for key- 
byte input. 
If the logic level on C/K is brought High, 
the DCP enters Direct Control mode, and the 
auxiliary port pins are converted into direct 
hardware status or control signals capable of 
instructing the DCP to perform cf functionally 
complete subset of its Cipher processing at 
very high throughputs. This operating mode is 
particularly well suited for Ciphering data for 
high-speed peripheral devices such as 
magnetic disk or tape. 


Data Flow. Bits M2 and M3 of the Mode 
register control the flow of data into and out of 
the DCP through the master and slave ports. 
Three basic configurations are prOVided: one 
single-port and two dual-port. 


Single-Port Configuration. The simplest con- 
figuration occurs when the Mode register con- 


STATUS 


figuration bits are set to master port only 
(Figure 4). In this operating configuration, the 
encrypt/decrypt bit (~) controls the process- 
ing of data. Data to be encrypted or decrypted 
is written to the master port Input register 
address. To facilitate monitoring of the Input 
register status, the MFLG signal goes Low 
when the Input register is not full. Data is read 
by the master CPU through the master port 
Output register address. Pin SFLGgoes Low 
when the Output register is not empty. MFLG 
is then redefined as a master input flag and 
SFLG is redefined as a master output flag. 
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Figuro 4. Single-Port Configuration. Mu'ltiplexed Control 
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Figure Sa. Dual-Port Configuration. Multiplexed Control 


Dual Port, Master Port Clear 
Configuration. In the dual-port configura- 
tions, both the master and slave ports are used 
for data entry and removal (Figures 5a and 
5b). In the master port clear configuration, 
clear text for encryption can be entered only 
through the master port, and clear text 
resulting from decryption can be read only 
through the master port. Cipher text can be 
handled only through the slave port. The 
actual direction of data flow is controlled 
either by the encrypt/decrypt bit (M4) in the 
Mode register or by the Start Encryption or 
Start Decryption commands. If encryption is 
specified, clear data will flow through the 
master port to the Input register, and cipher 
data will be available at the slave port when it 
is ready to be read from the Output register. 
F or decryption, the process is reversed, with 
Cipher data written to the Input register 
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Figure 5b. Dual-Port Configuration. Direct Control 
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through the master port. Slave port and clear 
text read from the Master port. 
In both dual-port configurations, the Master 


Port Flag (MFLG) and the Slave Port Flag 
(SFLG) are used to indicate the status of the 
data register associated with the master port 
and slave port, respectively. For example, dur- 
ing encryption in the master port clear con- 
figuration, MFLG goes Low (active) when the 
Input register is not full; SFLG goes Low 
(active) when the Output register is not empty. 
If cyphering operation changes direction, 
MFLG and SFLG switch their register associa- 
tion (see Table 1). 


Mode Register Bits 


Encryptl 
Port 


Decrypt Configuration. 
Bit M4 
Bit M3 
Bit M2 
a 
a 
a 
a 
a 
1 
a 
1 
a 
1 
a 
a 
1 
a 
1 
1 
1 
a 


Input 
Register 
Flag 


Output 
Register 
Flag 


SFLG 
MFLG 
SFLG 
MFLG 
SFLG 
SFLG 


Table 1. Association of Master Port Flag (MFLG) 
and Slave Port Flag (SFLG) 
with Input and Output Registers 


Dual Port, Slave Port Clear Configuration. 
This configuration is identical to the previously 
described dual-port, master port clear con- 
figuration except that the direction of cipher- 
ing is reversed. That is, all data flOWing in or 
out of the master port is cipher text, and all 
data at the slave port is clear text. 
Master Port Read/Write Timing. The master 
port of the DCP is designed to operate directly 
with a multiplexed address/data bus such as 
the Zilog Z-BUS. Several features of the master 
port logic are: 


[J The level on Master Port Chip Select (MCS) 
is latched internally on the rising (trailing) 
edge of Master Port Address Strobe (MAS). 
This action relieves external address decode 
circuitry of the responsibility for latching 
chip select at address time. 


II] The levels on MPI and MP2 are also latched 
internally on the rising edge of MAS and 
are subsequently decoded to enable reading 
and writing of the DCP's internal registers 
(Mode, Command, Status, Input and Out- 
put). This action also eliminates the need for 
external address latching and decoding. 


c Data transfers through the master port are 
controlled by the levels and transitions on 
Master Port Data Strobe (MDS) and Master 
Port Reac:l/Write (MR/W). The former con- 
trols the timing and the latter controls the 
transfer direction. Data transfers disturb 
neither the chip-select nor address latches, 


so once the DCP and a particular register 
have been selected, any number of reads or 
writes of that register can be accomplished 
without intervening address cycles. This 
feature greatly speeds up the loading of 
keys and data, given the necessary transfer 
control external to the DCP. 


Loading Keys and Initializing Vector (IV) 
Registers. Because the key and InitialiZing 
Vector (IV) registers are not directly 
addressable through any of the DCP's ports, 
keys and vector data must be loaded (and in 
the case of vectors, read) via \\command data 
sequences." Most of the commands recognized 
by the DCP are of this type. A load or read 
command is written to the Command register 
·through the master port. The command pro- 
cessor responds by asserting the Command 
Pending output. The user then either writes 
eight bytes of key or vector data through the 
master or auxiliary port, as appropriate to the 
speCific command, or reads eight bytes of vec- 
tor data from the master port. 
In Direct Control mode, only the E Key and 
D Key registers can be loaded; the M Key and 
IV registers are inaccessible. Loading the E 
and D Key registers is accomplished by plac- 
ing the proper state on the AU%-E/D input 
(High for E Key, Low for D Key) and then rais- 
ing the AUX7-K/D input-indicating that key 
loading is required. The command processor 
attaches the proper key register to the master 
port and asserts the AUX3-CP (Command 
Pending) signal (active Low). The eight key 
bytes can then be written to the master port. In 
the Multiplexed Control mode, all key and 
vector registers can be written to and all but 
the Master (M) Key register can be loaded with 
encrypted, as well as clear, data. If the opera- 
tion is a Load Encrypt command, the subse- 
quent data written to the master or auxiliary 
port (as appropriate) is routed first to the Input 
register and decrypted before it is written into 
the speCified key or InitialiZing Vector 
register. 
Parity Checking of Keys. Key bytes contain 
seven bits of key information and one parity 
bit. By DES deSignation, the low-order bit is 
the parity bit. The parity-check circuit is 
enabled whenever a byte is written to one of 
three key registers. The output of the parity- 
check circuit is connected to PAR and the 
state of this Signal is reflected in Status register 
'bit PAR (S3)' Status register bit PAR goes to 1 
whenever a byte with even parity (an even 
number of 1 s) is detected. In addition to the 
PAR bit, the Status register has a Latched Pari- 
ty bit (LP AR, S4) that is set to 1 whemever the 
Status register PAR bit goes to 1. Once set, the 
LPAR bit is not cleared until a reset occurs or 
a new Load Key command is issued. 
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When an encrypted key is entered, the 
parity-check logic operates only after the 
decrypted key is available. The encrypted data 
is not checked for parity. The PAR signal 
reflects the state of the decrypted bytes on a 
byte-to-byte basis as they are clocked through 


Initialization. The DCP can be reset in 
several ways: 


[J By the "Software Reset" command. 


[J By a hardware reset, which occurs 
whenever both MAS and MDS go Low 
simultaneously. 


lJ By writing to the Mode register. 


[J By aborting any command. 


These sequences initiate the same internal 
operations, except that loading the Mode 
register or aborting any command does not 
subsequently reset the Mode register. Once a 
reset process starts, the DCP is unable to 
respond to further commands for approximate- 
ly five clock cycles. If a power-up hardware 
reset is used, the leading edge of the reset 
signal should not occur until approximately 1 
ms after Vee has reached normal operating 
voltage. This delay time is needed for internal 
signals to stabilize. 


Registers. The registers in the DCP that can 
be addressed directly through the master port 
are shown with their addresses in Table 2. A 
brief description of these registers and those 
not directly accessible follows. 


C/K MP2 MPI MR/W MCS Register Addressed 


0 
X 
0 
0 
0 
Input Register 


0 
X 
0 
1 
0 Output Register 


0 
0 
1 
0 
0 
Command Register 


0 
0 
1 
1 
0 
Status Register 


0 
1 
1 
X 
0 
Mode Register 


X 
X 
X 
X 
1 No Register Accessed 
1 
X 
X 
0 
0 
Input Register 
1 
X 
X 
1 
0 Output Register 


Table 2. Master Port Register Addresses 


Pins 


the parity-check logic on their way to the key 
register. Thus, the time during which PAR 
indicates the status of a byte of decrypted key 
data may be as short as four clock cycles. The 
LPAR bit in the Status register indicates if any 
erroneous bytes of key data were entered. 


Hex 
Code 


90 
91 
92 
11 
12 


B1 
B2 
31 
32 


85 
84 
A5 
A4 


8D 
8C 
A9 
A8 


39 
41 
40 
CO 


EO 
00 


Command 


Load Clear M Key Through AUXiliary Port 
Load Clear E Key Through AUXiliary Port 
Load Clear D Key Through Auxiliary Port 
Load Clear E Key Through Master Port 
Load Clear D Key Through Master Port 


Load Encrypted E Key Through Auxiliary Port 
Load Encrypted D Key Through AUXiliary Port 
Load Encrypted E Key Through Master Port 
Load Encrypted D Key Through Master Port 


Load Clear rVE Through Master Port 
Load Clear IVD Through Master Port 
Load Encrypted IVE Through Master Port 
Load Encrypted IVD Through Master Port 


Read Clear IVE Through Master Port 
Read Clear rVD Through Master Port 
Read Encrypted IVE Through Master Port 
Read Encrypted IVD Through Master Port 


Encrypt With Master Key 
Start Encryption 
Start Decryption 
Start 


Stop 
Software Reset 


Table 3. Command Codes in Multiplexed Control Mode 


Command Register. Data written to the 8-bit, 
write-only Command register through the 
master port is interpreted as an instruction. A 
detailed description of each command is given 
in the Commands section; the commands 
and their hexadecimal representations are 
summarized in Table 3. A subset of these 
commands can be entered implicitly in Direct 
Control mode (elK High)-even though the 
Command register cannot be addressed in that 
mode-by transitions on auxiliary lines 
AUX5-S/S, AU~-E/D, and AUX7-K/D. These 
implicit commands are summarized in Table 4. 


C/K 
AUX7-K/O 
AUXs-E/D 
AUXs-S/S Command Initiated 


H 
L 
L 
t 
Start Decryption 
H 
L 
H 
t 
Start Encryption 
H 
L 
X 
1 
Stop 


H 
t 
L 
L 
Load D Key Clear through master port 
H 
t 
H 
L 
Load E Key Clear through master port 
H 
1 
X 
L 
End Load Key command 
H 
H 
X 
H 
Not allowed 
L 
Data 
Data 
Data 
AUX, pins become Key-Byte inputs 


Table 4. Implicit Command Sequences in Direct Control Mode 
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Status Register. The bit assignments in the 
read-only Status register are shown in Figure 
6. The PAR, AFLG, SFLG and MFLG bits 
indicate the status of the corresponding output 
pins, as do the busy and command pending 
bits when the DCP is in a Direct Control mode 
(C/K High). In each case, the output signal 
will be active Low when the corresponding 
status bit is a 1. The parity bit indicates the 
parity of the most recently entered key byte. 
The LPAR bit indicates whether any key byte 
with even parity has been encountered since 
the last Reset or Load Key command. 
The Busybit is 1 whenever the ciphering 
algorithm unit is actively encrypting or 
decrypting data, either as a response to a com- 
mand such as Load Encrypted Key (in which 
case the Command Pending bit is 1) or in the 
ciphering of regular text (indicated by the 
Start/Stop bit being 1). If the ciphered data 
cannot be transferred to the Output register 
because that register still contains output from 
a previous ciphering cycle, the Busy bit 
remains 1 even after the ciphering is complete. 
Busy is a at all other times, even when Cipher- 
ing is not possible because data has not been 
written to the Input register. 
The Command Pending bit is set to 1 by any 
command whose execution requires the 
transfer of data, to or from a nonaddressable 
internal register, such as when writing key 
bytes to the E key register or reading bytes 
from the IVE register. Thus, the Command 
Pending bit is set follOWing all commands ex- 


Mode Register. Bit assignments in this 5-bit 
read/write register are shown in Figure 7. The 
Cipher type bits (Ml and Mo) indicate to the 
DCP which ciphering algorithm is to be used. 
On reset, the Cipher Type mode defaults to 
Electronic Code Book mode. 
Configuration bits (M3 and M2) indicate 
which data ports are to be associated with the 
Input and Output registers and flags. When 
these bits are set to the single-port, master- 
only configuration (M3 M2 = 10), the slave 
port is disabled and no manipulation of Slave 
Port Chip Select (SCS) or Slave Data Strobe 
(SOS) can result in data movement through the 
slave port; all data transfers are accomplished 
thtough the master port, as previously 
described in the Functional Description. Both 
MFLG and SFLG are used in this configura- 
tion; MFLG gives the status of the Input 
register and SFLG gives the status of the Out- 
put register. 
When the configuration bits are set to one of 
the dual-port configurations (M3 M2 = 00 or 
01), both the master and slave ports are 
available for input and output. When M3, 
M2 = 01 (the default configuration), the 
master port handles clear data while the slave 
port handles encrypted data. Configuration 


cept the three start commands, the Stop com- 
mand and the Software Reset command. The 
Command Pending bit returns to a after all 
eight bytes have been transferred following 
Load Clear, Read Clear, or Read Encrypted 
commands; and after data has been transfer- 
red, decrypted, and loaded into the desired 
register follOWing Load Encrypt commands. 
The Start/Stop bit is set to 1 when one of the 
start commands is entered and it is reset to a 
whenever a reset occurs or when a new com- 
mand other than a Start is entered. 


~ 


L 
MASTER PORT FLAG 
o = INACTIVE 
1 = ACTIVE 


SLAVE PORT FLAG 
o = INACTIVE 
1 = ACTIVE 


AUXILIARY PORT FLAG 
o = INACTIVE 
1 = ACTIVE 
~--- PARITY (PAR) 
o = ODD PARITY 
1 = EVEN PARITY 
'------ LPAR 
o = ALL BYTES HAD 


ODD PARITY 


1 = ONE OR MORE BYTES 


HAD EVEN PARITY 
'------- BUSY 
o = NOT BUSY 
1 = BUSY 
'-------- COMMAND PENDING 
o = INACTIVE 
l' = ACTIVE 
~------ START/STOP 
o = STOP ENTERED 
1 = START ENTERED 


Figure 6. Status Register Bit Assignments 


M3, M2 = 00 reverses this assignment. Actual 
data direction at any particular moment is con- 
trolled by the Encrypt/Decrypt bit. 
The Encrypt/Decrypt bit (~) instructs the 


DCP algorithm processor to encrypt or decrypt 
the data from the Input register using the 
Ciphering method specified by the Cipher 
Type bits. The Encrypt/Decrypt bit also con- 
trols data flow within the DCP. For example, 
when the configuration bits are 0,1 (dual-port, 
master clear, slave encrypted) and the 
Encrypt/Decrypt bit is 1 (encrypt), clear data 
will flow into the DCP through the master port 
and encrypted data will flow out through the 
slave port. When the Encrypt/Decrypt bit is set 
to a (decrypt), data flow is reversed. 


RESERVED 
I L """ "" 
00 = ELECTRONIC CODE BOOK (DEFAULT) 
01 
= CIPHER FEEDBACK 


10 = CIPHER BLOCK CHAIN 
11 = RESERVED 


PORT CONFIGURATION 
00 = DUAL PORT, MASTER 
ENCRYPTED, SLAVE CLEAR 


01 = DUAL PORT, MASTER CLEAR, 


SLAVE ENCRYPTED (DEFAULT) 


10 = SINGLE PORT, MASTER ONLY 
11 = RESERVED 
'------ ENCRYPTIDECRYPT 


1 = ENCRYPT 
o = DECRYPT 


Figure 7. Mode Register Bit ASSignments 
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Input Register. The 64-bit, write-only Input 
register is organized to appear to the user as 
eight bytes of pushdown storage. A status cir- 
cuit monitors the number of bytes that have 
been stored. The register is considered empty 
when the data stored in it has been or is being 
processed; it is considered full when one byte 
of data has been entered in Cipher Feedback 
mode or when eight bytes of data have been 
entered in Electronic Code Book or Cipher 
Block Chain mode. If the user attempts to write 
data into the Input register when it is full, the 
Input register disregards the attempt; no data 
in the register is destroyed. 


Output Register. The 64-bit, read-only Output 
register is organized to appear to the user as 
eight bytes of pop-up storage. A status circuit 
detects the number of bytes stored in the Out- 
put register. The register is considered e~pty 
when all the data stored in it has been read by 
the master CPU and is considered full if it still 
contains one or more bytes of output data. If a 
user attempts to read data from the Output 
register when it is empty, the buffers driving 
the output bus remain in a 3-state condition. 


M, E, D Key Registers. The following 
multibyte key registers cannot be addressed 
directly, but are loaded in response to com- 
mands written to the Command register. 


All operations of the DCP result from com- 
mand inputs, which are entered in Multiplexed 
Control mode by writing a command byte to 
the Command register. Command inputs are 
entered in Direct Control mode by raiSing and 
lowering the logic levels on the AUX7-K/D, 
AUX6-E/15, and AUX5-S/S pins. Table 3 shows 
all commands that can be given in Multiplexed 
Control mode. Table 4 shows a subset of the 
impliCit commands that can be executed in the 
Direct Control mode. 


Load Clear M I{ey Through Auxiliary Port 
(90H). 
Load Clear E Key Through Auxiliary Port 
(91H). 
Load Clear D Key Through Auxiliary Port 
(92H). 
These commands may be used only for 
multiplexed operations; they override the data 
flow specifications set in the Mode register and 
cause the Master (M) Key, Encrypt (E) Key, or 
Decrypt (D) Key register to be loaded with 
eight bytes written to the auxiliary port. After 
the Load command is written to the Command 
register, the Auxiliary Port Flag (AFLG) goes 
active (Low) and the corresponding bit in the 
Status register (S2) becomes I, indicating that 
the device is able to accept key bytes at the 
auxiliary port pins. Additionally, the Com- 
mand Pending bit (S6) becomes 1 duri;ng the 
entire loading process. 


There are three 64-bit, write-only key 
registers in the DCP: the Master (M) Key 
register, the Encrypt (E) key register, and the 
Decrypt (D) key register. The Master key 
register can be loaded only with clear data 
through the auxiliary port. The Encrypt and 
Decrypt Key registers can be loaded in any of 
four ways: (l) as clear data through the aux- 
iliary port, (2) as clear data through the master 
port, (3) as encrypted data through the aux- 
iliary port, or (4) as encrypted data through 
the master port. In the last two cases, the 
encrypted data is first routed to the Input 
register, decrypted using the M Key, and final- 
ly written to the target key register from the 
Output register. 


Initializing Vector Registers (IVE and 
IVD). Two 64-bit registers are provided to 
store feedback values for cipher feedback and 
chained block ciphering methods. One initia- 
lizing vector register (lVE) is used during 
encryption, the other (lVD) is used during 
decryption. Both registers can be loaded with 
either clear or encrypted data through the 
master port (in the latter case, the data IS 
decrypted before being loaded into the IV 
register), and both may be read out either 
clear or encrypted through the master port. 


Each byte is written to its respective key 
register by placing an active Low signal on the 
Auxiliary Port Strobe (ASTB) once data has 
been set up on the aUXiliary port pins. The 
actual write process occurs on the rising (trail- 
ing) edge of ASTB. (See Switching Character- 
istics section for exact setup, strobe width, and 
hold times.) 
The Auxiliary Port Flag (AFLG) goes inac- 
tive immediately after the eighth strobe goes 
active (Low). However, the Command Pending 
bit (S6) remains 1 for several more clock 
cycles, until the key loading process is com- 
pleted. All key bytes are checked for correct 
(odd) parity as they are entered. 


Load Clear E Key Through Master Port 
(llH). 
Load Clear D Key Through Master Port 
(12H). 
These 'commands are available in both 
Multiplexed Control and Direct Control 
modes. They override the data flow specifica- 
tions set in the Mode register and attach the 
master port inputs to the Encrypt (E) Key or 
Decrypt (D) Key register, as appropriate, until 
eight key bytes have been written. In 
Multiplexed Control mode, the command is 
initiated by writing the Load command to the 
Command register. In Direct Control mode, 
the command is initiated by raising the 
AUX7-K/D control input while the AUX5-S/S 
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input is Low. In this latter case, the level on 
AU%-E/D determines which key register is 
written (High = E register). 


Once the command has been recognized, 
the Command Pending bit (S6 in the Status· 
register) becomes 1. In Direct Control mode, 
AUX3-CP goes active (Low), indicating that 
key entry may proceed. The host system then 
"writes exactly eight bytes to the master port (at 
the Input register address in Multiplexed Con- 
trol mode). When the key register has been 
loaded, the Command Pending bit returns to 
'0. In Direct Control mode, the AUX3-CP out- 
put goes inactive, indicating that the DCP can 
accept the next command. 


Load Encrypted E Key Through Auxiliary 
Port (BIH). 
Load Encrypted D Key Through Auxiliary 
Port (B2H). 
These commands are used in Multiplexed 
Control mode only. Their execution is similar 
to that of the Load Clear E (D) Key Through 
Auxiliary Port command, except that key bytes 
are first decrypted using the electronic code 
book algorithm and the Master (M) Key 
register. The key bytes are then loaded into 
the appropriate key register, after having 
passed through the parity-check logic. 
The Command Pending bit (S6) is 1 during 
the entire decrypt-and-load operation. In addi- 
tion, the Busy bit (S5) is 1 during the actual 
decryption process. 


Load Encrypted E Key Through Master Port 
(3IH). 
Load Encrypted D Key Through Master Port 
(32H). 
These commands are used in Multiplexed 
Control mode only. Their execution is similar 
in effect to that of the Load Clear E (D) Key 
Through Master Port command. The commands 
differ in that key bytes are initially decrypted 
using the electronic code book algorithm and 
the Master (M) Key register. Once decrypted, 
they are loaded byte-by-byte into the target 
key register, after having passed through the 
parity-check logic. 
The command pending bit (S6) is 1 during 
the entire decrypt-and-load operation. In addi- 
tion, the busy bit (S5) is 1 during the actual 
decryption process. 


Load Clear IVE Register Through 
Master Port (8SH) 
Load Clear IVD Register Through 
Master Port (84H) 
These commands are used in Multiplexed 
Control mode only. Their execution is virtually 
identicalto that of the Load Clear E (or D) Key 
Through Master Port command. The commands 
differ in that the data written to the input 
register address is routed to either the Encryp- 
tion Initializing Vector (lVE) or DecryptIon' 
Initializing Vector (IVD) register instead of a 
key register. No parity checking occurs. The 


Commtlnd Pending bit (S6) is 1 during the 
entire loading process. 


Load Encrypted IVE Register Through 
Master Port (ASH). 
Load Encrypted IVD Register Through 
Master Port (A4H). 
These commands are analogous to the Load 
Encrypted E (or D) Key Through Master Port 
command. The data flow specifications set in 
the Mode register are overridden and the eight 
vector bytes are decrypted using the Decryp- 
tion (D) Key register and the electronic code 
book algorithm. The resulting clear vector 
bytes are loaded into the target Initializing 
Vector register. No parity checking occurs. 
The Busy bit (S5) does not become 1 during 
the decryption process, but the Command 
Pending bit (S6) is 1 during the entire 
decryption-and-load operation. 


Read Clear IVE Register Through 
Master Port (8DH). 
Read Clear IVD Register Through 
Master Port (8CH). 
In the Multiplexed Control mode, these com- 
mands override the data flow specifications 
set in the Mode register and connect the 
appropriate Initializing Vector register to the 
master port at the Output register address. In 
this state, each IV register appears as eight 
bytes of FIFO storage. The first byte of data is 
available six clocks after loading the Com- 
mand register. The Command Pending bit in 
the Status register remains a 1 until sometime 
after the eighth byte is read out. The host 
system is responsible for reading exactly eight 
bytes. 


Read Encrypted IVE Register Through 
Master Port (A9H). 
Read Encrypted IVD Register Through 
Master Port (A8H). 
In the Multiplexed Control mode only, these 
commands override the specifications set in 
the Mode register and encrypt the contents of 
the specified Initializing Vector register using 
the electronic code book algorithm and the 


. Encrypt (E) key. The resulting cipher text is 
placed in the output register, where it can be 
read as eight bytes through the master port. 
During the actual encryption process, the Busy 
bit (S5) is 1. When the Busy bit becomes 0, the 
encrypted vector bytes are ready to be read 
out. The Command Pending bit (S6) is 1 
during the entire encryption and output pro- 
cess; it becomes 0 when the eighth byte is read 
out. The host system is responsible for reading 
exactly eight bytes. 


Encrypt with Master (M) Key (39H). 
In the Multiplexed Control mode; this com- 
mand overrides the data flow specifications set 
in the Mode register and causes the DCP to 
accept eight bytes from the master port, which 
are written to the Input register. When eight 
bytes ha~e been received, the DCP encrypts 
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the input using the Master (M) Key register. 
The encrypted data is loaded into the Output 
register, where it can be read out through the 
master port. The Command Pending bit (S6) 
and the Busy (Ss) bit are used as status 
indicators in the three phases of this operation. 
The Command Pending bit becomes 1 as 
soon as the Input register can accept data. 
When exactly eight bytes have been entered, 
the Busy bit becomes and remains 1 until the 
encryption process is complete. When 'Busy 
becomes 0, the encrypted data is available to 
be read out. The Command Pending bit 
returns to 0 when the eighth byte has been 
read. 
Start Encryption (41H) 
Start Decryption (40H) 
Start (COH) . . 


The three start commands begin normal data 
ciphering by setting the Status register's 
Start/Stop bit (S7) to 1. The Start Encryption 
and Start Decryption commands explicitly 
specify the ciphering direction by forCing the 
Encrypt or Decrypt bit (M4) in the Mode 
register to 1 or 0, respectively. The Start com- 
mand, however, uses the current state of the 
Encrypt/Decrypt bit, as speCified in a previous 
Mode register load. 
When a start command has been entered, 
the port status flag (MFLG or SFLG) asso- 
ciated with the Input register becomes active 
(Low), indicating that data may be written to 


The control and/or data signals and the 
timing requirements for clock/reset, Direct 
Control mode, Multiplexed Control mode 
(master port)' master (slave) port read/write, 
and auxiliary port key' entry functions are 
illustrated in Figures 8 through 12. The ac 
switching characteristics of the signals 
involved in the above functions are described 
in the AC Characteristics. The specific timing 
periods described are identified by numerics 
(1 through 48), which are referenced in both 
the timing diagrams and in the AC 
Characteristics. 
A two-to-seven character symbol is listed in 
AC Characteristics for each period described. 
The symbol speCifies the signal(s) involved, the 
state of each signal, and optionally, the port 
associated with a signal. Symbols are encoded 
as follows: 


General Form: Ta Ab (Cb) 


Where: 
(1) T is a constant. 


(2) a represents anyone of the following sym- 
bols: 
Symbol Meaning 
c 
Clock 
d 
Delay 
f 
Fall Time 


the Input register to begin ciphering. 
In Direct Control mode, the Start command 
is issued by raising the level on the AUXs-S/S 
input (Table 4). The ciphering direction is 
specified by the level on AU~-E/D. If 
AU~-E/D is High when AUXs-S/S goes High, 
the command is Start Encryption; if A U%-E/D 
is Low, it is Start Decryption. 


Stop (EOH). 
The Stop command clears the Start/Stop bit 
(S7) in the Status register. This action causes 
the input flag (MFLG or SFLG) to become 
inactive and inhibits the loading of any further 
input into the algorithm unit. If ciphering is in 
progress [Busy bit (Ss) is 1 or AUX2-BSY is 
active], it is allowed to finish, and any data in 
the Output register remains accessible. 
In Direct Control mode, the Stop command 
is implied when the signal level on the 
Auxs-s/s input goes from High to Low 
(Table 4). 


Software Reset (00). 


This command has the same effect as a hard- 
ware reset (MAS and MDS Low): it forces the 
DCP back to its default configuration, and all 
processing flags go into Inactive mode. The 
default configuration includes setting the Mode 
register to Electronic Code Book ciphering 
mode and establishes a dual-port configuration 
. with master port clear and slave port 
encrypted. 


h 
Hold Time 
r 
Rise Time 
s 
Setup Time 
w 
Width 
(3) A,C represent any of the following signal 
names: 
Symbol Signal Name 
A 
Address Strobe 
B 
BSY, Busy 
C 
Clock 
D* 
Data In or the address 
at the master port. 
E 
E/D, EnablelDisable 
F* 
Flag (MFLG, SFLG, or 
(AFLG) 
G* 
Data Strobe (MDS', 
SDS, or ASTB) 


K 
KID, KeylData 
M 
CIK, Control/Key 
Mode 
N 
SIS, Start/Stop 


P 
PAR, Parity 


Q* 
Data Out (master or 
slave port) 


R 
CP, Clock Pulse 
S* 
Chip Select (master or 
slave port) 
W 
MRIW, Master Port 


read/write 
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(4) 
b represents anyone of the 
following signal state descrip- 
tors (symbol). 
. 


For example: Dl specifies data 
in at Master Port; F2 specifies 
Slave Port flag-SFLG. 


II 


Number 


1 
2 
3 


Symbol 
State Indicated 
h 
High 


I 
Low 
v 
Valid 
x 
Invalid 
z 
High Impedance 


* These signal names may be 
tnbdified by the folloWing op- 
tional numeric port identifiers: 
Identifier Port 


I 
Master Port 


2 
Slave Port 


3 
AUX (Key) Port 


Syhlbol 
Parameter 


Clock 


nvCh 
Clock Width (High) 


TwCl 
Clock Width (Low) 


Tbc 
Clock Cycle Time 
Reset 


Figure 8. Clock and Reset 


Min 


105 
105 
250 


Max 
Notes*t 


4 - 
TdGhl(Glh) - 
MDS*MAS Low to MDS*MAS High -- TC ---------- 
(Reset Pulse Width) 
5 
TdC(Glh) 
Clock High to MDS*MAS High 
0 
50 


Direct Control Mode 
6 
T~Ni<Mh) 
sis Low to ClK High (Setup) 
2TC 


7 -- tsKl(Mh) -- KID Low to ClK High (Setup) ---- 
8 
tdMh(Nh) 
C/K High to SIS high 


2TC 
4TC 


9 
TdMh(Kh) 
ClK High to KID High 
4TC 


10 
TsEv(Kh) 
E/D Valid to KID High (Setup) 
2TC 


11-- TdKh(Rl) -- KID High to CP Low ----------- 200 
12 
ThKl (Ex) 
KID Low to E/D Invalid (Hold) 
TC 


13. 
TdGl(Nh) 
Clock Low to SIS Valid 
20 
80 


14 
TsE:v(Hn) 
E/D Valid to SIS High (Setup) 
2TC 
IS --TdNh(Fll) -- SIS High to MFLG (SFLG) Low -------- 230 


(Port Input Flag) 
16 
TdCh(Fll) 
Clock High to MFLG (SFLG) Low 
230 


(Port Input Flag) 


17 
TdCh(Bl) 
Clock High to BSY Low 
300 


18 -- TdCl(Bh) -- Block Low to BSY High ---------- 
19 
TdCh(Fll) 
Clock High to MFLG (SFLG) Low 


220 
230 


(Port Output Flag) 


20 
TdNI(Flh) 
SIS Low to MFLG (SFLG) High 
230 
2 
(Port Input Flag) 
Multiplexed Control Mode - Master Port 


21 
TwAl 
MAS Width (Low) 
80 


22 
TdWY(Ah) 
MRlW Valid to MAS High 
40 


23 
TsSli(Ah) 
MCS Low to MAS High (Setup) 
0 


24 --ThAh(Slh) -- MAS High to MCS High (Hold) 
60 ---------- 
25 
tsDlv(Ah) 
Address-In Valid to MAS High 
55 


26 
ThAh(Dlx) 
(Address Setup Time) 


MAS High to Address-In Invalid 
(Address Hold Time) 


• Notes referenced at end 01 AC Characteristics table. 
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C/K 
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KID 
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MFLO} 
SFLG INPUT PORT 


MFLO } OUTPUT PORT 
SFLG 
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Number 
Symbol 
Parameter 
Min 
Max 
Notes*t 


Master (Slave) Port Read/Write 


27 
TdSll(Gll) 
MCS (SCS) Low to MDS (SDS) Low 
70 


28 
ThGlh(S1h) 
MDS (SDS) High to MCS (SCS) High 
0 
3 
(Select Hold Time) 
29 
TsWv(Gll) 
MRlW Valid to MDS Low (Setup) 
70 
30 -- ThG lh(Hwx) - 
MDS High to MR/W Invalid (Hold) 
0 ---------- 
31 
TwGll(G1h) 
MDS (SDS) Low to MDS (SDS) High 
Width-Write Data Read 
125 
Width-Status Register Read 
155 
32--TdCl(Glh)--Clock Low to MDS (SDS) High 
20---70----- 


33 
TdGlh(HGIl) 
MDS (SDS) High to MDS (SDS) Low 
125 
(Data Strobe Recovery Time) 
34 
TsD1r(H1h) 
Write-Data Valid to MDS (SDS) High 
Setup Time-Key Load 
200 
--------- Setup Time-Data Write 
100 ----------- 
Setup Time-Command/Mode 
100 


Register Write 
35 
ThGlh(Dlx) 
MDS (SDS) High to Write-Data 
40 


Invalid (Hold Time-All Writes) 
36--TdGll(Qlv)-- MDS (SDS) Low to Read-Data Valid -------------- 
Read Access Time-Status Register 
Read Access Time-Data 
37 
ThGlh(Qlx) 
MDS (SDS) High to Read-Data Invalid 
5 
(Read Hold Time) 


155 
120 
80 


38--TdGll(Flh)-- MDS (SDS) Low to MFLG (SFLG)-------125 ---4-- 
High (Last Strobe) 
39 
TdGll(Rh) 
MDS High to CP High 
TC+280 
(Last Strobe, Key Load) 


40 
ThGl(HNl) 
MDS (SDS) High to SIS Low 
3TC 
(Hold Time After La.st Input Strobe) 
41 
TdG1(HPv) 
MDS High to PAR Valid (Key Write) 
200 


• Notes referenced at end of AC Characteristics table. 
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,'l 


Figure 9. Control and Status Signals (Direct Control Model 
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AC 
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(Continued) 


402 


Number 
Symbol 
Parameter 
Min 


Auxiliary Port Key Entry 
42 
TwG3 
ASTB Low to ASTB High (Width) 
160 
43 
TdCI(G3h) 
Clock Low to ASTB High 
20 


44 
TdG3h(G31) 
ASTB High to Next ASTB Low 
125 
(Recovery Time) 
45 
TsD3v(G3h) 
Write-Data Valid to ASTB High 
200 


(Data Setup Time) 
46 
ThG3h(D3x) 
ASTB High to Write-Data Invalid 
40 


(Data Hold Time) 
47 
TdG3h(Pr) 
ASTB High to PAR Valid 


48 
TdG31(F3h) 
ASTB Low to AFLG High 
(Last Strobe) 


NOTES: 
• All transition times are assumed to be ::s; 20 ns. 
3. Direct Control mode only. 


Max 
Notes*t 


70 


200 
230 


All units in nanoseconds (ns). All timings are 
preliminary and subject to change. 
1. Parameter TaCh(Fll) applies to all input blocks ex- 
cept the first (when sis first goes High). 
2. When SIS goes inactive (Low) in Direct Control 
mode, the flag associated with the !nput port turns off. 


4. In Cipher Feedback mode, the port flag (MFLG or 
SFLG) goes inactive following the leading edge of the 
first data strobe (MDS or SDS); in all other modes and 
operations, the flags go inactive on the eighth data 
strobe. 


CLK 
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MCS 


MPIAD) 


WRITE 
MR/W 


MDS 


MPIAD) 


READ 
MR/W 


Figure 10. Master Port. Multiplexed Control Mode Read/Write Timing 
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CLK 


MR/W 


WRITE 
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~i~~ ----------------------< tj 


36 
- - - - --"X' - - - - 
~Xr - - - - - - 


-~------~'~)----------~'~)------------ 


41 


Figure 11. Master (Slave) Port Read/Write 
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Figure 12. Auxiliary Fort Key Entry 
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Product Package/ 
Number 
Temp. 


Z8068 
DS 


Speed 
Description 


4.0 MHz 
DCP (40-pin) 


NOTES: D = Cerdip, S = O°C to 70°C. 


Product Package/ 
Number 
Temp. 
Speed 
Description 
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Universal 


Peripherals 


Zilog 


Pioneering the 
Microworld 


Zilog's Universal Peripheral 


Components Family is more than 
a group of simple I/O circuits- 
they are lintelligent, fully program- 
mable devices capable of 
performing complicated tasks 
independently. Their capabilities 
unburden the master CPU, reduce 
bus traffic, increase system 
throughput, and greatly simplify 
overall system hardware design 
requirements. 
The peripheral components, 
where needed, are produced in 
two versions to increase their 
range of application. One version, 
identified by the number Z80xx, is 
capable of interfacing with Zilog's 
multiplexed Z-BUS only or with 
both the Z-BUS and conventional 
multiplexed buses. The second 
version, identified by the number 
Z85xx, is capable of interfacing 
with conventional nonmultiplexed 
buses. Many of these Z85xx 
peripherals will function with and 
add capability to non-Zilog CPUs. 
Contact your local Zilog sales off- 
ice, local distributor or represen- 
tative for additional information 
and detailed specifications. This 
section of the data book includes 
only product specifications or 
product briefs on the Z85xx 
series of components. For the 
specifications or briefs on the 


Two Versnons Extend 
lBange off Applications 
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Z80xx components refer to the 
Z8000 peripherals section. 


All of the peripheral com- 


ponents are extensively program- 
mable to permit each to be 
tailored to its own application(s). 
All Z-BUS peripherals share com- 
mon interrupt and bus-request 
structures; they can also be 
operated in either a: p~iority! 
interrupt or polled environment. 
Counting, timing, and parallel 
I/O transfer problems are easily 
solved using the Z8036/Z8536 
CIO Counter/Timer and 1/0 Unit. 
This component has three 16-bit 
counter/timers, three I/O ports, 
and can double as a program- 
mable priority-interrupt controller. 
Data communications problems 


are neatly handled by the Z80301 
Z8530 SCC Serial Communica· 
tions Controller. This device is a 
serial, dual-channel, multi- 
protocol controller which supports 
all popular communications for- 
mats. The SCC supports virtually 
all serial data transfer applica- 
tions. 


Interface problems with the 
interconnection of major com- 
ponents within an asynchronous, 
parallel processor system can be 
solved using the Z8038 Z·FIO 
FIFO 1/0 Interface Unit. This 


general-purpose interface unit 
provides expandable, bidirectional 
buffering between asynchronous 
CPUs in a parallel processing net- 
work, or between a CPU and 
peripheral circuits and/or devices. 
The Z-FIO can be used with 
systems having either multiplexed 
or nonmultiplexed buses. 
General-purpose control and 
data manipulation problems are 
easily handled by the Z8090/4 
and Z8590/4 UPC Universal 
Peripheral Controller. The U PC 
is a complete microcomputer 
designed for off-line applications. 
This microcomputer executes the 
same friendly, .capable instruction 
set as Zilog's Z8 microcomputer; 
it has three I/O ports, six levels of 
priority-interrupt, and 2K bytes of 
memory on chip. The UPC is in- 
tended for applications that re- 
quire an intelligent peripheral con- 
troller that can assume many of 
the tasks normally required of the 
master CPU. 


Two new universal peripherals 
have been added to the ever 
expanding line of Zilog peripher- 
als. They are the Z8581 Clock 
Generator and Controller (CGC) 
and the Z8531 ASCC Asyn· 
chronous Serial Communica· 
tions Controller. 


407 


The Z8581 Clock Generator 
and Controller (CGC) is a ver- 
satile addition to Zilog's family of 
universal microprocessor com- 
ponents. The selective clock- 
stretchin-g capabilities and variety 
of timing outputs of this device 
allow it to meet the timing design 
requirements of various micro- 
processors easily, including those 
of LSI and VLSI peripherals. 
The outputs of the Z8581 CGC 


directly drive the Z80 and Z8000 


408 


microprocessor clock inputs. The 
oscillator input frequency refer- 
ence sources can be either 
crystals or TIL-compatible 
oscillators. 
To complement the 


Z8530/Z8030 SCC Serial Com- 
munications Controller, Zilog has 
introduced an asynchronous ver- 
sion designated the Z8531 ASCC. 
It features two independent 0 to 
1 M bit/second, full-duplex chan- 
nels-each with a separate 


crystal oscillator, baud rate 
generator and digital phase- 
locked loop for clock recovery. 
The Z8581 ASCC has program- 
mable NRZ, NRZI, or FM data 
encoding. 
The LSI and VLSI components 
now available can meet the 
design needs of today, while Zilog 
continues to design state-of-the- 
art devices for the needs of 
tomorrow. 


Zil 


Features 


General 
Description 


2023·001, 002 


[] Two independent, a to 1M bit/second, full- 
duplex channels, each with a separate 
crystal oscillator, baud rate generator, and 
Digital Phase-Locked Loop for clock 
recovery. 


[] Multi-protocol operation under program 
control; programmablfi! for NRZ, NRZI, or 
FM data encoding. 


C Asynchronous mode with five to eight bits 
and one, one and one-half, or two stop bits 
per character; programmable clock factor; 
break detection and generation;' parity, 
overrun, and framing error detection. 


The Z8530 SCC Serial Communications 
Controller is a dual-channel, multi-protocol 
data communications peripheral designed for 
use with conventional non-multiplexed buses. 
The SCC functions as a serial-to-parallel, 
parallel-to-serial converter/controller. The 
SCC can be software-configured to satisfy a 
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o Synchronous mode with internal or external 
character synchronization on one or two 
synchronous characters and CRC genera- 
tion and checking with CRC-16 or 
CRC-CCITT preset to either Is or as. 


o SDLC/HDLC mode with comprehensive 
frame-level control, automatic zero insertion 
and deletion, I-field residue handling, abort 
generation and detection, CRC generation 
and checking, and SDLC Loop mode 
operation. 


t:J Local Loopback and Auto Echo modes. 


wide variety of serial communications applica- 
tions. The device contains a variety of new, 
sophisticated internal functions including 
on-chip baud rate generators, Digital Phase- 
Locked Loops, and crystal oscillators that 
dramatically reduce the need for external 
logic. 
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Figuro 2. Pin Assignmonts 
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The SCC handles asynchronous formats, 


Synchronous byte-oriented protocols such as 
IBM Bisync, and Synchronous bit-oriented pro- 
tocols such as HDLC and IBM SDLC. This ver- 
satile device supports Virtually any serial data 
transfer application (cassette, diskette, tape 
drives, etc.). 
The device can generate and check CRC 
codes in any Synchronous mode and can be 
programmed to check data integrity in various 
modes. The SCC also has facilities for 


The following section describes the pin 
functions of the SCC. Figures 1 and 2 detail 
the respective pin functions and pin 
assignments. 
AlB. Channel A/Channel B Select (input). 
This signal selects the channel in which the 
read or write operation occurs. 


CEo Chip Enable (input, active Low). This 
signal selects the SCC for a read or write 
operation. 


CTSA. CTSB. Clear To Send (inputs, active 
Low). If these pins are programmed as Auto 
Enables, a Low on the inputs enables the 
respective transmitters. If not programmed as 
Auto Enables, they may be used as general- 
purpose inputs. Both inputs are Schmitt-trigger 
buffered to accommodate slow rise-time inputs. 
The SCC detects pulses on these inputs and 
can interrupt the CPU on both logic level 
transitions. 
Die. Data/Control Select (input). This signal 
defines the type of information transferred to 
or from the SCC. A High means data is 
transferred; a Low indicates a command. 


DCDA. DCDB. Data Carrier Detect (inputs, 
active Low). These pins function as receiver 
enables if they are programmed for Auto 
Enubles; otherv;ise they muy be used uS 
general-purpose input pins. Both pins are 
Schmitt-trigger buffered to accomodate slow 
rise-time signals. The SCC detects pulses on 
these pins and can interrupt the CPU on both 
logic level transitions. 
Do-I>? Data Bus (bidirectional, 3-state). These 
lines carry data and commands to and from 
the SCC. 


DTR/REQA. DTR/REQB. Data Terminal 
Ready/Request (outputs, active Low). These 
outputs follow the state programmed into the 
DTR bit. They can also be used as general- 
purpose outputs or as Request lines for a DMA 
controller. 
lEI. Interrupt Enable In (input, active High). 
IEI is used with IEO to form an interrupt daisy 
chain when there i~ more than one interrupt- 
driven device. A High IEI indicates that no 
other higher priority device has an interrupt 
under service or is requesting an interrupt. 


modem controls in both channels. In appli- 
cations where these controls are not needed, 
the modem controls can be used for 
general-purpose I/O. 


The Z-Bus daisy-chain interrupt hierarchy is 
also supported-as is standard for Zilog 
peripheral components. 
The Z8530 SCC is packaged in a 40-pin 
ceramic DIP and uses a single + 5 V power 
supply. 


lEO. Interrupt Enable Out (output, active 
High). lEO is High only if lEI is High and the 
CPU is not servicing an SCC interrupt or the 
SCC is not requesting an interrupt (Interrupt 
Acknowledge cycle only). IEO is connected to 
the next lower priority device's IEI input and 
thus inhibits interrupts from lower priority 
devices. 
INT. Interrupt Request (output, open-drain, 
active Low). This signal is activated when the 
SCC requests an interrupt. 


IN TACK. Interrupt AckrlOwledge (input, active 
Low). This signal indicates an active Interrupt 
Acknowledge cycle. During this cycle, the 
SCC interrupt daisy chain settles. When RD 
becomes active, the SOC places an interrupt 
vector on the data bus (if IEI is High). 
INTACK is latched by the rising edge 
of PCLK. 
. 


PCLK. Clock (input). This is the master SCC 
clock used to synchronize internal signals 
PCLK is a TTL level signal. 


RD. Read (input, active Low). ni.is signal indi- 
cates a read operation and when the SCC is 
selected, enables the SCC's bus drivers. Dur- 
ing the Interrupt Acknowledge cycle, this 
signal gates the interrupt vector onto the bus 
if the SCC is the highest priority device 
requesting an interrupt. 


RxDA. RxDB. Receive Data (inputs, active 
High). These input signals receive serial data 
at standard TTL levels. 


RTxCA. RTxCB. Receive/Transmit Clocks 
(inputs, active Low). These pins can be pro- 
grammed in several different modes of opera- 
tion. In each channel, RTxC may supply the 
receive clock, the transmit clock, the clock for 
the baud rate generator, or the clock for the 
Digital Phase-Locked Loop. These pins can 
also be programmed for use with the respec- 
tive SYNC pins as a crystal oscillator. The 
receive clock may be I, 16, 32, or 64 times the 
data rate in. Asynchronous modes. 


RTSA. RTSB. Request To Send (outputs, 
active Low). When the Request To Send (RTS) 
bit in Write Register 5 (Figure 11) is set, the 
RTS signal goes Low. When the RTS bit is 
reset in the Asynchronous mode and Auto 
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Enable is on, the signal goes High after the 
transmitter is empty. In Synchronous mode or 
in Asynchronous mode with Auto Enable off, 
the RTS pin strictly follows the state of the RTS 
bit. Both pins can be used as general-purpose 
outputs. 


SYNCA. SYNCB. Synchronization (inputs or 
outputs, active Low). These pins can act either 
as inputs, outputs, or part of the crystal 
oscillator circuit. In the Asynchronous Receive 
mode (crystal oscillator option not selected), 
these pins are inputs similar to CTS and DCD. 
In this mode, transitions on these lines affect 
the state of the Synchronous/Hunt status bits in 
Read Register 0 (Figure 10) but have no other 
function. 
In External Synchronization mode with the 
crystal oscillator not selected, these lines also 
act as inputs. In this mode, SYNC must be 
driven Low two receive clock cycles after the 
last bit in the synchronous character is 
received. Character assembly begins on the 
rising edge of the receive clock immediately 
preceding the activation of SYNC. 


In the Internal Synchronization mode 
(Monosync and Bisync) with the crystal 
oscillator not selected, these pins act as out- 
puts and are active only during the part of the 
receive clock cycle in which synchronous 
characters are recognized. The synchronous 


The functional capabilities of the SCC 


can be described from two different points 
of view: as a data communications device, 
it transmits and receives data in a wide 
variety of data communications protocols; as a 
microprocessor peripheral, the SCC offers 
valuable features such as vectored interrupts, 
polling, and simple handshake capability. 
Data Communications Capabilities. The 
SCC provides two independent full-duplex 
channels programmable for use in' any com- 
mon Asynchronous or Synchronous data- 
communication protocol. Figure 3 and the 


PARITY 


STfT 
! sr 
p 


condition is not latched, so these outputs are 
active each time a synchronization pattern is 
recognized (regardless of character bound- 
aries). In SDLC mode, these pins act as 
outputs and are valid on receipt ofa flag. 


TxDA. TxDB. Transmit Data (outputs, active 
High). These output signals transmit serial data 
at standard TTL levels. 
--- --- 
TRxCJ.'I\. TRxCB. Transmit/Receive Clocks 
(inputs or outputs, active Low). These pins can 
be programmed in several different modes of 
operation. TRxC may supply the receive clock 
or the transmit clock in the input mode or sup- 
ply the output of the Digital Phase-Locked 
Loop, the crystal oscillator, the baud rate 
generator, or the transmit clock in the output 
mode. 


WR. Write (input, active Low). When the SCC 
is selected, this signal indicates a write 
operation. The coincidence of RD and WR is 
interpreted as a reset. 


W IREQA. W IREQB. Wait/Request (outputs, 
open-drain when programmed for a Wait func- 
tion, driven High or Low 'when programmed 
for a Request function). These dual-purpose 
outputs may be programmed as Request lines 
for a DMA controller or as Wait lines to syn- 
chronize the CPU to the SCC data rate. The 
reset state is Wait. 


follOWing description briefly detail these 
protocols. 
Asynchronous Modes. Transmission and 
reception can be accomplished independently 
on each channel with five to eight bits per 
character, plus optional even or odd parity. 
The transmitters can supply one, one-and-a- 
half, or two stop bits per character and can 
provide a break output at any time. The 
receiver break-detection logic interrupts the 
CPU both at the start and at the end of a 
received break. Reception is protected from 
spikes by a transient spike-rejection 
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Figure 3. Some see Protocols 
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mechanism that checks the signal one-half a 
bit time after a Low level is detected on the 
receive data input (RxDA or RxDB in 
Figure 1). If the Low does not persist (as in the 
case of a transient), the character assembly 
process does not start. 
Framing errors and overrun errors are 
detected and buffered together with the partial 
character on which they occur. Vectored inter- 
rupts allow fast servicing or error conditions 
using dedicated routines. Furthermore, a 
built-in checking process avoids the interpreta- 
tion of a framing error as a new start bit: a 
framing error results in the addition of one-half 
a bit time to the point at which the search for 
the next start bit begins. 
The SCC does not require symmetric 
transmit and receive clock signals-a feature 
allowing use of the wide variety of clock 
sources. The transmitter and receiver can 
handle data at a rate of I, 1/16, 1/32, or 1/64 
of the clock rate supplied to the receive and 
transmit clock inputs. In Asynchronous modes, 
the SYNC pin may be programmed as an input 
used for functions such as monitoring a ring 
indicator. 
Synchronous Modes. The SCC supports both 
byte-oriented and bit-oriented synchronous 
communica tion. Synchronous byte-oriented 
protocols can be handled in several modes, 
allowing character synchronization with a 6-bit 
or 8-bit synchronous character (Monosync), 
any 12-bit synchronization pattern (Bisync), or 
with an external synchronous signal. Leading 
sync characters can be removed without inter- 
rupting the CPU. 


Five- or 7-bit synchronous characters are 
detected with 8- or 16-bit patterns in the SCC 
by overlapping the larger pattern across multi- 
ple incoming synchronous characters as shown 
in Figure 4. 


CRC checking for Synchronous byte- 


oriented modes is delayed by one character 
time so that the CPU may disable CRC check- 
ing on specific characters. This permits the 
implementation of protocols such as 
IBM Bisync. 
Both CRC-16 (X16 + XI5 + X2 +. 1) and 


CCITT (X16 + XI2 + X5 + 1) error checking 
polynomials are supported. Either polynomial 
may be selected in all Synchronous modes. 
Users may preset the CRC generator and 
checker to all Is or all Os. The SCC also pro- 
vides a feature that automatically transmits 
CRC data when no other data is available for 
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transmission. This allows for high speed 
transmissions under DMA control, with no 
need for CPU intervention at the end of a 
message. When there is no data or CRC to 
send in. Synchronous modes, the transmitter 
inserts 6-, 8-, or 16-bit synchronous 
characters, regardless of the programmed 
character length. 
The SCC supports Synchronous bit-oriented 
protocols, such as SDLC and HDLC, by per- 
forming automatic flag sending, zero insertion, 
and CRC generation. A special command can 
be used to abort a frame in transmission. At 
the end of a message, the SCC automatically 
transmits the CRC and trailing flag when the 
transmitter underruns. The transmitter may 
also be programmed to send an idle line con- 
sisting of continuous flag characters or a 
steady marking condition. 
If a transmit underrun occurs in the middle 
of a message, an external/status interrupt 
warns the CPU of this status change so that an 
abort may be issued. The SCC may also be 
programmed to send an abort itself in case of 
an underrun, relieVing the CPU of this task. 
One to eight bits per character can be sent, 
allowing reception of a message with no prior 
information about the character structure in 
the information field of a frame. 
The receiver automatically acquires syn- 
chronization on the leading flag of a frame in 
SDLC or HDLC and provides a synchroniza- 
tion signal on the SYNC pin (an interrupt can 
also be programmed). The receiver can be 
programmed to search for frames addressed by 
a single byte (or four bits within a byte) of a 
user-selected address or to a global broadcast 
address. In this mode, frames not matching 
either the user-selected or broadcast address 
are ignored. The number of address bytes can 
be extended under software control. For 
receiving data, an interrupt on the first 
received character, or an interrupt on every 
character, or on special condition only (end- 
of-frame) can be selected. The receiver 
automatically deletes all Os inserted by the 
transmitter during character assembly. CRC is 
also calculated and is automatically checked to 
validate frame transmission. At the end of 
transmission, the status of a received frame is 
available in the status registers. In SDLC 
mode, the SCC must be programmed to use 
the SDLC CRC polynomial, but the generator 
and checker may be preset to all Is or all Os. 
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Figure 4. Detecting 5- or 7-Bit Synchronous Characters 
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The CRC is inverted before transmission and 
the receiver checks against the bit pattern 
0001110100001111. 
NRZ, NRZI or FM coding may be used in any 


Ix mode. The parity options available in Asyn- 
chronous modes are available in Synchronous 
modes. 
The SCC can be conveniently used under 
DMA control to provide high speed reception 
or transmission. In reception, for example, the 
SCC can interrupt the CPU when the first 
character of a message is received. The CPU 
then enables the DMA to transfer the message 
to memory. The SCC then issues an end-of- 
frame interrupt and the CPU can check the 
status of the received message. Thus, the CPU 
is freed for other service while the message is 
being received. The CPU may also enable the 
DMA first and have the SCC interrupt only on 
end-of-frame. This procedure allows all data to 
be transferred via the DMA. 
SOLe Loop Mode. The SCC supports SDLC 
Loop mode in addition to normal SDLC. In an 
SDLC Loop, there is a primary controller 
station that manages the message traffic flow 
on the loop and any number of secondary 
stations. In SDLC Loop mode, the SCC per- 
forms the functions of a secondary station 
while an SCC operating in regular SDLC 
mode can act as a controller (Figure 5). 
A secondary station in an SDLC Loop is 
always listening to the messages' being sent 
around the loop, and in fact must pass these 
messages to the rest of the loop by retrans- 
mitting them with a one-bit-time delay. The 
secondary station can place its own message 
on the loop only at specific times. The con- 
troller signals that secondary stations may 
transmit messages by sending a special 
character, called an EOP (End Of Poll), 
around the loop. The EOP character is the bit 
pattern 11111110. Because of zero insertion 
during messages, this bit pattern is unique and 
easily recognized. 
When a secondary station has a message to 
transmit and recognizes an EOP on the line, it 


Figure 5. An SDLe Loop 


changes the last binary 1 of the EOP to a 0 
before transmission. This has the effect of turn- 
ing the EOP into a flag sequence. The secon- 
dary station now places its message on the loop 
and terminates the message with an EOP. Any 
secondary stations further down the loop with 
messages to transmit can then append their 
messages to the message of the first secondary 
station by the same process. Any secondary 
stations without messages to send merely echo 
the: incoming messages and are prohibited 
from placing messages on the loop (except 
upon recognizing an EOP). 
SDLC Loop mode is a programmable option 
in the SCC. NRZ, NRZI, and FM coding may 
all be used in SDLC Loop mode. 
Baud Rate Generator. Each channel in the 
SCC contains a programmable baud rate 
generator. Each generator consists of two 8-bit 
time constant registers that form a 16-bit time 
constant, a 16-bit down counter, and a flip-flop 
on the output producing a square wave. On 
startup, the flip-flop on the output is set in a 
High state, the value in the time constant 
register is loaded into the counter, and the 
counter starts counting down. The output of 
the baud rate generator toggles upon reaching 
0, the value in the time constant register is 
loaded into the counter, and the process is 
repeated. The time constant may be changed 
at any time, but the new value does not take 
effect until the next load of the counter. 
The output of the baud rate generator may 
be used as either the transmit clock, the 
receive clock, or both. It can also drive the 
Digital Phase-Locked Loop (see next section). 
If the receive clock or transmit clock is not 
programmed to come from the TRxC pin, the 
output of the baud rate generator may be 
echoed out via the TRxC pin. 
The following formula relates the time con- 


stant to the baud rate (the baud rate is in 
bits/second and the BR clock period is in 
seconds): 


baud rate = 
2 (time constant + 2) x (BR dock period) 


Digital Phase-Locked Loop. The SCC con- 


tains a Digital Phase-Locked-Loop (DPLL) to 
recover clock information from a data stream 
with NRZI or FM encoding. The DPLL is driven 
by a clock that is nominally 32 (NRZI) or 16 
(FM) times the data rate. The DPLL uses this 
clock, along with the data stream, to construct 
a clock for the data. This clock may then be 
used as the SCC receive clock, the transmit 
clock, or both. 
For NRZI encoding, the DPLL counts the 32x 
clock to create nominal bit times. As the 32x 
clock is counted, the DPLL is searching the 
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incoming data stream for edges (either 1 to 0 
or 0 to 1). Whenever an edge is detected, the 
DPLL makes a count adjustment (during the 
next counting cycle), producing a terminal 
count closer to the center of the bit cell. 
For FM encoding, the DPLL still counts from 
o to 31, but with a cycle corresponding to two 
bit times. When the DPLL is locked, the clock 
edges in the data stream should occur between 
counts 15 and 16 and between counts 31 and 
O. The DPLL looks for edges only during a 
time centered on the 15 to 16 counting 
transition. 
The 32x clock for the DPLL can be pro- 
grammed to come from either the RTxe input 
or the output of the baud rate generator. The 
DPLL output may be programmed to be 
echoed out of the see via the TRxe pin (if 
this pin is not being used as an input). 
Data Encoding. The see may be pro- 
grammed to encode and decode the serial data 
in four different ways (Figure 6). In NRZ 
encoding, a 1 is represented by a High level 
and a 0 is represented by a Low level. In NRZI 
encoding, a 1 is represented by no change in 
level and a 0 is represented by a change in 
level. In FMl (more properly, bi-phase mark), 
a transition occurs at the beginning of every 
bit cell. A 1 is represented by an additional 
transition at the center of the bit cell and a 0 is 
represented by no additional transition at the 
center of the bit cell. In FMO (bi-phase space), 
a transition occurs at the beginning of every 
bit cell. A 0 is represented by an additional 
transition at the center of the bit cell, and a 1 
is represented by no additional transition at 
the center 'of the bit cell. In addition to these 
four methods, the sec can be used to decode 
Manchester (bi-phase level) data by using the 
DPLL in the FM mode and programming the 
receiver for NRZ data. Manchester encoding 
always produces a transition at the center of 
the bit cell. If the transition is 0 to I, the bit is 
a O. If the transition is 1 to 0, the bit is a 1. 
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Auto Echo and Local Loopback. The see is 
capable of automatically echoing everything it 
receives. This feature is useful mainly in 
Asynchronous modes, but works in Syn- 
chronous and SDLe modes as well. In Auto 
Echo mode, TxD is RxD. Auto Echo mode can 
be used with NRZI or FM encoding with no 
additional delay, because the data stream is 
not decoded before retransmission. In Auto 
Echo mode, the CTS input is ignored as a 
transmitter enable (although transitions on this 
input can still cause interrupts if programmed 
to do so). In this mode, the transmitter is 
actually bypassed and the programmer is 
responsible for disabling transmitter interrupts 
and WAIT/REQUEST on transmit. 
The see is also capable of local loopback. 
In this mode TxD is RxD, just as in Auto Echo 
mode. However, in Local Loopback mode, the 
internal transmit data is tied to the internal 
receive data and RxD is ignored (except to be 
echoed out via 'TxD). The eTS and DeD 
inputs are also ignored as transmit and receive 
enables. However, transitions on these inputs 
can still cause interrupts. Local Loopback 
works in Asynchronous, Synchronous and 
SDLe modes with NRZ, NRZI or FM coding of 
the data stream. 
I/O Interface Capabilities. The see offers 
the choice of Polling, Interrupt (vectored or 
non vectored) , and Block Transfer modes to 
transfer data, status, and control information to 
and from the epu. The Block Transfer mode 
can be implemented under epu or DMA 
control. 
Polling. All interrupts are disabled. Three 
status registers in the sec are automatically 
updated whenever any function is performed. 
For example, end-of-frame in SDLe mode 
sets a bit in one of these status registers. The 
idea behind polling is for the epu to 
periodically read a status register until the' 
register contents indicate the need for data to 
be transferred. Only one register needs to be 
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Figure 6. Data Encoding Methods 
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read; depending on its contents, the CPU 
either writes data, reads data, or continues. 
Two bits in the register indicate the need for 
data transfer. An alternative is a poll of the 
Interrupt Pending register to determine the 
source of an interrupt. The status for both 
channels resides in one register. 


Interrupts. When an SCC responds to an 
Interrupt Acknowledge signal (INTACK) from 
the CPU, an interrupt vector may be placed on 
the data bus. This vector is written in WR2 and 
may be read in RR2A or RR2B (Figures 10 
and 11). 
To speed interrupt response time, the SCC 


can modify three bits in this vector to indicate 
status. If the vector is read in Channel A, 
status is never included; if it is read in 
Channel B, status is always included. 
Each of the six sources of interrupts in the 


SCC (Transmit, Receive, and External/Status 
interrupts in both channels) has three bits 
associated with the interrupt source: Interrupt 
Pending (IP), Interrupt Under Service (IUS), 
and Interrupt Enable (IE). Operation of the IE 
bit is straightforward. If the IE bit is set for a 
given interrupt source, then that source can 
request interrupts. The exception is when the 
MIE (Master Interrupt Enable) bit in WR9 is 
reset and no interrupts may be requested. The 
IE bits are write only. 
The other two bits are related to the inter- 
rupt priority chain (Figure 7). As a 
microprocessor peripheral, the SCC may 
request an interrupt only when no higher 
priority device is requesting one, e. g . , when 
IEI is High. If the device in question requests 
an interrupt, it pulls down INT. The CPU then 
responds with INTACK, and the interrupting 
device places the vector on the data bus. 
In the SCC, the IP bit signals a need for 
interrupt servicing. When an IP bit is 1 and 
the IEI input is High, the INT output is pulled 
Low, requesting an interrupt. In the SCC, if 
. the IE bit is nOt set by enabling interrupts, 
then the IP for that source can never be set. 
The IP bits are readable in RR3A. 
The IUS bits signal that an interrupt request 
is being serviced. If an IUS is set, all interrupt 
sources of lower priority in the SCC and 
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external to the SCC are prevented from 
requesting interrupts. The internal interrupt 
sources are inhibited by the state of the inter- 
nal daisy chain, while lower priority devices 
are inhibited by the IEO output of the SCC 
being pulled Low and propagated to subse- 
quent peripherals. An IUS bit is set during an 
Interrupt Acknowledge cycle if there are no 
higher priority devices requesting interrupts. 
There are three types of interrupts: 
Transmit, Receive, and External/Status. Each 
interrupt type is enabled under program con- 
trol with Channel A having higher priority 
than Channel B, and with Receiver, Transmit, 
and External/Status interrupts prioritized in 
that order within each channel. When the 
Transmit interrupt is enabled, the CPU is 
interrupted when the transmit buffer becomes 
empty. (This implies that the transmitter must 
have had a data character written into it so 
that it can become empty.) When enabled, the 
receiver can interrupt the CPU in one of three 
ways: 


• Interrupt on First Receive Character or 


Special Receive Condition. 


II Interrupt on All Receive Characters or 


Special Receive Condition. 


II Interrupt on Special Receive Condition 


Only. 


Interrupt on First Character or Special Con- 
dition and Interrupt on Special Condition Only 
are typically used with the Block Transfer 
mode. A Special Receive Condition is one of 
the following: receiver overrun, framing -error 
in Asynchronous mode, end-of-frame inSDLC 
mode and, optionally, a parity error. The 
Special Receive Condition interrupt is different 
from an ordinary receive character available 
interrupt only in the status placed in the vector 
during the Interrupt Acknowledge cycle. In 
Interrupt on First Receive Character, an inter- 
rupt can occur from Special Receive Condi- 
tions any time after the first receive character 
interrupt. 
The main function of the External/Status 
interrupt is to monitor the signal transitions of 
the CTS, DCD, and SYNC pins; however, an 
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lEI 00-07 iNT INTACK lEO 
lEI 00-07 iNT INTACK lEO 
lEI 00"07 iNT INTACK 
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INT.-------------~1---------------~_1----------------~4_~ 


INTACK~--------------~ ________________ _4----------------~ 


Figure 7. Interrupt Schedule 
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External/Status interrupt is also caused by a 
Transmit Underrun condition, or a zero count 
in the baud rate generator, or by the detection 
of a Break (Asynchronous mode), Abort (SDLC 
mode) or EOP (SDLC Loop mode) sequence in 
the data stream. The interrupt caused by the 
Abort or EOP has a special feature allowing 
the SCC to interrupt when the Abort or EOP 
sequence is detected or terminated. This 
feature facilitates the proper termination of the 
current message, correct initialization of the 
next message, and the accurate timing of the 
Abort condition in external logic in SDLC 
mode. In SDLC Loop mode, this feature allows 
secondary stations to recognize the wishes of 
the primary station to regain control of the 
loop during a poll sequence. 


The SCC internal structure includes two full- 
duplex channels, two baud rate generators, 
internal control and interrupt logic, and a bus 
interface to a nonmultiplexed bus. Associated 
with each channel are a number of read and 
write registers for mode control and status 
information, as well as logiC necessary to inter- 
face to modems or other external devices 
(Figure 8). 
The logiC for both channels provides 
formats, synchronization, and validation for 
data transferred to and from the channel inter- 
face. The modem control inputs are monitored 
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CPU/DMA Block Transfer. The SCC provides 
a Block Transfer mode to accommodate CPU 
block transfer functions and DMA controllers. 
The Block Transfer mode uses the WAITI 
REQUEST output in conjunction with the 
WaiVRequest bits in WRI. The WAITI 
REQUEST output can be defined under soft- 
ware control as a WAIT line in the CPU Block 
Transfer mode or as a REQUEST line in the 
DMA Block Transfer mode. 
To a DMA controller, the SCC REQUEST 


output indicates that the SCC is ready to 
transfer data to or from memory. To the CPU, 
the WAIT line indicates that the SCC is not 
ready to transfer data, thereby requesting that 
the CPU extend the IIO cycle. The DTRI 
REQUEST line allows full-duplex operation 
under DMA control. 


by the control logic under program control. 
All of the modem control signals are general- 
purpose in nature and can optionally be used 
for functions other than modem control. 
The register set for each channel includes 
ten control (write) registers, two sync- 
character (write) registers, and four status 
(read) registers. In addition, each baud rate 
generator has two (read/write) registers for 
holding the time constant that determines the 
baud rate. Finally, associated with the inter- 
rupt logic is a write register for the interrupt 
vector accessible through either channel, a 
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Figure 8. Block Diagram of see Architecture 
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Archi tecture 
( Continued) 
write only Master Interrupt Control register 
and three read registers: one containing the 
vector with status infomation (Channel B only), 
one containing the vector without status 
(Channel A only), and one containing the 
Interrupt Pending bits (Channel A only). 
The registers for each channel are 
designated as follows: 


WRO-WR15 - 
Write Registers 0 through 15. 
RRO-RR3, RRlO, RRI2, RR13, RR15 - 
Read 
Registers 0 through 3, 10, 12, 13, 15. 
Table 1 lists the functions assigned to each 
read or write register. The SCC contains only 
one WR2 and WR9, but they can be accessed 
by either channel. All other registers are 
paired (one for each channel). 
Data Path. The transmit and receive data path 
'illustrated in Figure 9 is identical for both 
channels. The receiver has three 8-bit buffer 
registers in an FIFO arrangement, in addition 
to the 8-bit receive shift register. This scheme 
creates additional time for the CPU to service 
an interrupt at the beginning of a block of 
high speed data. Incoming data is routed 
through one of several paths (data or CRC) 
depending on the selected mode (the character 
length in Asynchronous modes also determines 
the data path). 
The transmitter has an 8-bit Transmit Data 
buffer register loaded from the internal data 
bus and a 20-bit Transmit Shift register that 
can be loaded either from the synchronous 
character registers or from the Transmit Data 
register. Depending on the operational mode, 
outgoing data is routed through one of four 
main paths before it is transmitted from the 
Transmit Data output (TxD) 


Programming 
The SCC contains 13 write registers in each 
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channel that are programmed by the system 
separately to configure the functional per": 
sonality ofthe channels. 
In the SCC, register addressing is direct for 
the data registers only, which are selected by 
a High on the Die pin. In all other cases (with 
the exception of WRO and RHO), programming 
the write registers requires two write opera- 
tions and reading the read registers requires 
both a write and a read operation. The first 
write is to WRO and contains three bits that 
point to the selected register. The second write 
is the actual control word for the selected 
register, and if the second operation is read, 


RRO 


RRI 


RR2 


RR3 


RR8 


RRIO 


RR12 


RR13 


Read Register Functions 


Transmit/Receive buffer status and External status 


Special Receive Condition status 


Modified interrupt vector (Channel B only) 
Unmodified interrupt vector (Channel A only) 


Interrupt Pending bits (Channel A only) 


Receive buffer 


Miscellaneous status 


Lower byte of baud rate generator time constant 


Upper byte of baud rate generator time constant 


RR 15 
External/Status interrupt information 


Write Register Functions 


WRO 
CRC initialize. initialization commands for the 
various modes, Register Pointers 


WRI 
Transmit/Receive interrupt and data transfer mode 
definition 


WR2 
Interrupt vector (accessed through either channel) 


WR3 
Receive parameters and control 


WR4 
Transmit/Receive miscellaneous parameters and 
modes 
WR5 
Transmit parameters and controls 


WR6 
Sync characters or SDLC address field 


WR7 
Sync character or SDLC flag 


WR8 
Transmit buffer 


WR9 
Master interrupt control and reset (accessed 
through either channel) 


WRIO 
Miscellaneous transmitter/receiver control bits 


WR 11 
Clock mode control 


WR12 
Lower byte of baud rate generator time constant 


WR13 
Upper byte of baud rate generator time constant 


WR14 
Miscellaneous control bits 


WR15 
External/Status interrupt control 


Table 1. Read and Write Register Functions 


the selected read register is accessed. All of 
the registers in the SCC, including the data 
registers, may be accessed in this fashion. The 
pointer bits are automatically cleared after the 
read or write operation so that WHO (or RRO) is 
addressed again. 
The system program first issues a series of 
commands to initialize the basic mode of 
operation. This is followed by other commands 
to qualify conditions within the selected mode. 
F or example, the Asynchronous mode, 
character length, clock rate, number of 'stop 
bits, even or odd parity might be set first. 
Then the interrupt mode would be set, and 
finally, receiver or transmitter enable. 
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Read Registers. The SCC contains eight read 
registers (actually nine, counting the receive 
buffer (RR8) in each channel). Four of these 
may be read to obtain status information (RRO, 
RRl, RRlO, and RR15). Two registers (RR12 
and RR13) may be read to learn the baud rate 
generator time constant. RR2 contains either 
the unmodified interrupt vector (Channel A) or 
the vector modified by status information 


Read Register 0 
I 0,1 061 051 0.1 OJ I 0,1 0, I Do I 
~ 


I llli ~~~~;;,~~;:::.,~'" 
LS 
SYNC/HUNT 


CTS 


Tx UNDERRUN/EOM 


'-------- BREAK/ABORT 


Read Register 1 


10,1 06 \ 051 0.\ OJ I 0,1 0, I Do I 
~~ 


I ~:::':::'''''' 
~ 
RESIDUE CODE 1 


RESIDUE CODE 0 


PARITY ERROR 


Rx OVERRUN ERROR 


CRC/FRAMING ERROR 
'-------- END OF FRAME (SD~C) 


Read Register 2 


10, I 06105 \ 0.\ OJ 10,1 0, I Do I 


~i: 


INTERRUPT VECTOR' 


~------------V7 


'MODIFIED IN B CHANNEL 


Read Register 3 


~~ 


I ~ 
~::~~:~:~:~~~TATIP' 
L 
CHANNEL B Rx IP' 


CHANNEL A EXT/STAT IP' 


CHANNEL A Tx IP' 


CHANNEL A Rx IP' 
o 
'--------0 


'ALWAYS 0 IN B CHANNEL 


(Channel B). RR3 contains the Interrupt Pen- 
ding (IP) bits (Channel A). Figure 10 shows 
the formats for each read register. 
The status bits of RRO and RRI are carefully 
grouped to simplify status monitoring; e.g., 
when the interrupt vector indicates a Special 
Receive Condition interrupt, all the appro- 
priate error bits can be read from a single 
register (RR 1) . 


Read Register 10 


'----------- ONE CLOCK MISSING 


Read Register 12 


I 0, \ 061 05 \ 0.\ OJ \ 0,\ 0, I 
Do I 


~:j 
'--------- TC7 


Read Register 13 


~------------- TC'5 


Read Register 15 


I~I~I~I~I~I~I~I~I 


LOWER BYTE OF 
TIME CONSTANT 


UPPER BYTE OF 
TIME CONSTANT 


II ~ 
~;;~:::::' 
~"''' 
Tx UNDERRUN/EOM IE 
'-------- BREAK/ABORT IE 


Figure 10. Read Rogister Bit FUDctions 


419 


Programming 
(Continued) 


420 


Write Registers. The SCC contains 13 write 
registers (14 counting WR8, the transmit 
buffer) in each channel. These write registers 
are programmed separately to configure the 
functional "personality" of the channels. In 
addition, there are two registers (WR2 and 


Write Register 0 


0 
0 
0 
REGISTER 0 


0 
0 
REGISTER 1 


0 
1 
REGISTER 2 


0 
1 
REGISTER 3 


1 
0 
REGISTER 4 


1 
0 
1 
REGISTER 5 


1 
1 
0 
REGISTER 8 


1 
REGISTER 7 


0 
REGISTER 8 


). 


0 
0 
1 
REGISTER 9 


0 
1 
0 
REGISTER 10 


0 
1 
REGISTER 11 


1 
0 
REGISTER 12 


1 
0 
1 
REGISTER 13 


1 
1 
REGISTER 14 


1 
1 
REGISTER 15 


o 0 
0 
NULL CODE 
o 0 
1 
POINT HIGH 


o 1 
0 
RESET EXT/STAT INTERRUPTS 


o 1 
1 
SEND ABORT (SDLC) 


1 
0 
ENABLE INT ON NEXT Rx CHARACTER 


1 
0 
RESET TxlNT PENDING 


1 
1 
0 
ERROR RESET 


1 
1 
1 
RESET HIGHEST IUS 


o 0 
NULL CODE 
o 1 
RESET Rx CRC CHECKER 


1 
0 
RESET Tx CRC GENERATOR 


1 
1 
RESET Tx UNDERRUN/EOM LATCH 


'WITH POINT HIGH COMMAND 


Write Register 1 


I 0,1 Os I 05 1 0.1 031 0,1 0, I Do I 
I L!: '" '" '""" 
Tx INT ENABLE 


PARITY IS SPECIAL CONDITION 


o 
0 
Rx INT DISABLE 


o 
1 
Rx INT ON FIF1ST CHARACTER OR SPECIAL CONDITION 


1 
OINT ON ALL Rx CHARACTERS OR SPECIAL CONDITION 


1 
1 
Rx INT ON SPECIAL CONDITION ONLY 
'------- WAITIDMA REQUEST ON RECEIVE/TRANSMIT 
'-------- WAITIDMA REQUEST FUNCTION 
'--------- WAIT/DMA REQUEST ENABLE 


Write Register 2 


I 0,1 Os I 05 1 0.1 031 0,1 0, I Do I 


WR9) shared by the two channels that may be 
accessed through either of them. WR2 contains 
the interrupt vector for both channels, while 
WR9 contains the interrupt control bits. Figure 
11 shows the format of each write register. 


Write Register 3 


1 0, I Os I 051 0.1 031 0,1 0, I Do I 
~~ 


I 
LRXENABLE 
L 
SYNC CHARACTER LOAD INHIBIT 


ADDRESS SEARCH MODE (SDLC) 


Rx CRC ENABLE 


ENTER HUNT MODE 


AUTO ENABLES 


o 
0 
Rx 5 BITS/CHARACTER 


o 
1 
Rx 7 BITS/CHARACTER 


1 
0 
Rx 6 BITS/CHARACTER 


1 
1 
Rx 8 BITS/CHARACTER 


Write Register 4 


I 0,1 Os I 05 1 0,1 03 1 0,1 0, I Do I 
I 


I L 
PARITY ENABLE 
L 
PARITY EVEN/tfOD 


o 
0 
SYNC MODES ENABLE 
o 
1 
1 STOP BIT/CHARACTER 


1 
0 
1 y, STOP BITS/CHARACTER 


1 
1 
2 STOP BITS/CHARACTER 


o 
0 
8 BIT SYNC CHARACTER 
o 
1 
16 BIT SYNC CHARACTER 
o 
SDLC MODE (01111110 FLAG) 


1 
1 
EXTERNAL SYNC MODE 


o 
0 
X1 CLOCK MODE 


o 1 
X16 CLOCK MODE 


1 
0 
X32 CLOCK MODE 


1 
1 
X64 CLOCK MODE 


Write Register 5 


~ 


I L!: :~SCRC ENABLE 
L 
SDLC/CRC.16 


. 
Tx ENABLE 


SEND BREAK 


o 
0 
Tx 5 BITS (OR LESS)/CHARACTER 


o 
1 
Tx 7 BITS/CHARACTER 


1 
0 
Tx 6 BITS/CHARACTER 


1 
1 
Tx 8 BITS/CHARACTER 
'--------- DTR 


Write Register 6 


10, I Os I 05 1 0.1 031 0,1 0, I Do I 


INTERRUPT 
VECTOR 
~)~~ 


L-_______ V, 


SYNC, 
SYNCs 
SYNC1 
SYNCo 
SYNC, 
SYNCs 
SYNC3 
SYNC2 
ADR, 
ADRs 


ADR, 
ADRs 


SYNCs 
SYNCs 
SYNCs 
SYNC1 
ADRs 
ADRs 


SYNC, 
SYNC, 
SYNC, 
SYNCo 
ADR, 
ADR, 


Figure 11. Write Register Bit Functions 


SYNCo 
SYNCo 
SYNCo 


1 
ADRo 


MONOSYNC, 8 BITS 
MONOSYNC, 6 BITS 
BISYNC, 16 BITS 
BISYNC, 12 BITS 
SDLC 
SDLC 
(ADDRESS RANGE) 


2016-006 2023-010 


t- 


Programming 
(Continued) 


2016·006 


Write Register 7 


I 0, I 061 
Os I 0.1 0,1 0,1 0, I Do I 


Write Register 9 


SYNC7 
SYNCs 
SYNC,s 
SYNC" 
o 


10, I 0,1 051 
D. i 031 0,1 0, I Do I 


SYNCe 
SYNC4 
SYNC14 
SYNClO 


1 


SYNCs 
SYNC3 
SYNC13 
SYNCg 


1 


~ 
lJ£:: 
~MIE 


~TATUS HIGH/STATUSJ:OW 


o 
0 
NO RESET 


o 
1 
CHANNEL RESET B 


1 
0 
CHANNEL RESET A 


1 
1 
FORCE HARDWARE RESET 


Write Register 10 


~lJ£ 


L 6 BIT/8BTf SYNC 


LOOP MODE 


ABORT/FLAG ON UNDERRUN 


MARK/FLAG IDLE 


GO ACTIVE ON POLL 


o 
0 
NRZ 


o 
1 
NRZI 


1 
0 
FMl (TRANSITION = 1) 


1 
1 
FMO (TRANSITION = 0) 
'---------- CRC PRESET I/O 


Write Register 11 


o 
1 
TRxC OUT = TRANSMIT CLOCK 


SYNC. 
SYNC2 
SYNC'2 
SYNCe 


1 


1 


0 
0 
TRxC OUT = XTAL OUTPUT 


1 
0 
TRxC OUT = BA GENERATOR OUTPUT 


1 
1 
TRxC OUT = DPLL OUTPUT 


'rRxC o/i 


o 
0 
TRANSMIT CLOCK = RTxC PIN 


o 
1 
TRANSMIT CLOCK = TRxC PIN 


1 
0 
TRANSMIT CLOCK = BR GENERATOR OUTPUT 


1 
1 
TRANSMIT CLOCK = DPLL OUTPUT 


o 
0 
RECEIVE CLOCK = Rtxc PIN 


o 
1 
RECEIVE CLOCK = TRxC PIN 


1 
D 
RECEIVE CLOCK = BR GENERATOR OUTPUT 


1 
1 
RECEIVE CLOCK = DPLL OUTPUT 


L---------R~XTAUNOXTAL 


SYNC3 
SYNC, 
SYNC" 
SYNC7 


1 


SYNC2 
SYNCo 
SYNC,o 
SYNC, 


1 


SYNC, 


X 
SYNCg 
SYNCs 


1 


SY~Co 


SYNCs 


SYNC~ 
o 


MONOSYNC, 8 BITS 
MONOSYNC, 6 BIT;'> 
BISYNC, 16 BITS 
BISYNC, 12 BITS 
SDLC 


Write Register l~ 


I 0, I 061 05 i 0.1 0,1 0,1 0, 100 I 


~:~ 


LOWER BYTE OF 
TIME CONSTANT 


Write Register 13 


UPPER BYTE OF 
TIME CONSTANT 


L-_______ TC,s 


Write Register H 


I 0, I 0.1 051 0.1 0,1 02 1 0, I Do I 


0 
0 
0 


0 
0 
1 


0 
1 
0 


0 
1 
1 


1 
0 
0 


1 
0 
1 


1 
1 
0 


1 
1 
1 


~@. 


L BR. GENfRATOR ENABLE 
L 
IlR GENERATOR SOURCE 


DTRIREQUEST FUNCTION 
I 
• 
, 
AUTO ECHQ 


I 
LOCAL LOOPBACK 


NULL CQM¥A~P 


ENTER St;:ARGH MODE 


RESET MISSING CI.OCK 


DISAB~E DPI.!. 


SET $)lllflC;E l' ~R GENI'RATqR 


SET SPURI;E = RTxC 


SET fM IJIOD~ 


SET NR;!:I ~ODE 


Write Registe~ l& 


ID'IDm·ID~SID~'II'I[~ :"'''''''' 


CDCDI~ 


SYNC/HUNT IE 


CTS IE 


T~ \JNDEflRj.lN/EOM IE 
L-____ 
....... ..,...,...-_ BREAK/ABORT IE 


Figure ll. Write Register Bit Functions (Continued) 


421 


Timing 


422 


The SCC generates internal control signals 
from WR and RD that are related to PCLK. 
Since PCLK has no phase relationship with 
WR and RD, the circuitry generating these 
internal control signals must provide time for 
metastable conditions to disappear. This gives 
rise to a recovery time related to PCLK. The 
recovery time applies only between bus trans- 
actions involving the SCC. The recovery time 
required for proper operation is speCified from 
the rising edge of WR or RD in the first trans- 


action involving the SCC to the falling edge of 
WR or RD in the second transaction involving 
the SCC. This time must be at least 6 PCLK 
cycles plus 200 ns. 
Read Cycle Timing. Figure 12 illustrates 
Read cycle timing . Addresses on AlB and Die 
and the status on INT ACK must remain stable 
throughout the cycle. If CE falls after RD falls 
or if it rises before RD rises, the effective RD is 
shortened. 


AlB, ole 
X 
ADDRESS VALID 
V-- 
_----J _ _ _ _ _ _ _ 
"----- 


\ 


\\0.----_--11 


\'---- 
1 


00-07 ------------«\.. ____ -'x 
DATA VALID »)------ 


Figure 12. Read Cycle Timing 


Write Cycle Timing. Figure 13 illustrates 
Write cycle timing. Addresses on AlB and Die 
and the status on INTACK must remain stable 


throughout the cycle. If CE falls after WR falls 
or if it rises before WR rises, the effective WR 
is shortened. 


AlB, ole 
X 
ADDRESS VALID 
V-- 
_----J _ _ _ _ _ _ 
.-"----- 


\ 


\\.-____ -..JI 


\_-- 
I 


00-07------------~(\.. ______ 
D_AT_A_VA_L_ID _____ ___')~--------- 


Figure 13. Write Cycle Timing 


Interrupt Acknowledge Cycle Timing. Figure 
14 illustrates Interrupt Acknowledge cycle 
timing. Between the time INTACK goes Low 
and the falling edge of RD, the internal and 
external IEI/IEO daisy chains settle. If there is 
an interrupt pending in the SCC and lEI is 


High when RD falls, the Acknowledge cycle is 
intended for the SCC. In this case, the SCC 
may be programmed to respond to RD Low by 
placing its interrupt vector on Do-D7 and it 
then sets the appropriate Interrupt-Under- 
Service latch internally. 


INTACK ~'-------~>O'l~--------------------'J' 


~----------~£~'--~\~ ____________ _'J' 


00-07 ---------I/,F-' --------«'-___ -'X 
VECTOR »)------ 


Figure 14. Interrupt Acknowledge Cycle Timing 


2023-003, 004, 005 


Absolute 
Maximum 
Ratings 


Standard 
Test 
Conditions 


DC 
Charac- 
teristics 


Capacitance 


8085-006, 001 


Voltages on all inputs and outputs 
with respect to GND .. : ....... -0.3 V to + 7.0 V 
Operating Ambient 
Temperature ................. As Specified in 
Ordering Information 
Storage Tempera ture ........ -65°C to + 150 °C 


The characteristics below apply for the 
following standard test conditions, unless 
otherwise noted. All voltages are referenced to 
GND. Positive current flows into the refer- 
enced pin. Standard conditions are as follows: 


+5V 


Figure 15. Standard Test Load 


Symbol 
Parameter 
Min 


VIH 
Input High Voltage 
2.0 
VIL 
Input Low Voltage 
-0.3 
VOH 
Output High Voltage 
2.4 


VOL 
Output Low Voltage 


IlL 
Input Leakage 


IOL 
Output Leakage 
Icc 
Vee Supply Current 


Stresses greater than those listed under Absolute Maxi- 


mum Ratings may cause permanent damage to the device. 
This is a stress rating only; operation of the device at any 
condition above those indicated in the operational sections 
of these speCifications is not implied. Exposure to absolute 
maximum rating conditions for extended periods may affect 
device reliability. 


[J +4.75 V ::5 Vee ::5 +5.25 V 


III GND = 0 V 


II TA as specified in Ordering Information 
All ac parameters assume a load capacitance 
of 50 pF max. 


Max 


Vee+ 0.3 
0.8 


0.4 


± 10.0 
± 10.0 
250 


+5V 


FROM OUTPUT ~ 


2'2K 


UNDER TEST 
. 
r 


50PF 


Figure 16. Open-Drain Test Load 


Unit 


V 
V 
V 
V 
p.A 
p.A 
rnA 


Condition 


IOH = -250 p.A 
IOL= +2.0 rnA 
0.4 S VIN S + 2.4V 
0.4 S VOUT S +2.4V 


Vee = 5 V ± 5% unless otherwise specified, over speCified temperature range. 


Symbol 
Parameter 
Min 
Max 
Unit 
Test Condition 


CIN 
Input Capacitance 
10 
pF 
Unmeasured Pins 


COUT 
Output Capacitance 
15 
pF 
Returned to Ground 


CIIO 
Bidirectional Capacitance 
20 
pF 


f = 1 MHz, over specified temperature range. 
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Read and 
Write 
Timing 
PCLK -'I\.- ~ 


AlB, ole ~ 
'" 
I----<D f----- 


- 
~r----®---- 


~®-I---- 
l-f®- 


Hv-~ 


00-07 


READ 


WR 


00-07 
WRITE 


W/REQ 


WAIT 


WIREQ 


REQUEST 


OTR/REQ 


REQUEST 


No. 
Symbol 
Parameter 


1 
TwPCl 
PCLK Low Width 
2 
TwPCh 
PCLK High Width 
3 
TfPC 
PCLK Fall Time 
4 
TrPC 
PCLK Rise Time 


-Y- 
~ 
@-r-H 


17 


~ 
®-1- 


-& 


15 


I' 


~ 


31 


~ 


34 


~-:h )~ 
r-' 
5 
3 r=-::--0 
l( 


1----0-~ -j®f.of- 


-- 
-® ~~ 
-- ---./ 
I--®-- 


I 
~1\ 


~ 
-® 


) 


~ 


~ 
@-- 
~~ HD- 


1- 


~ 
J 
-I 
l( 


~kID· 


\ !--- 


J 
I-®- 


J 


IJ6' 


37 
J 


4MHz 
SMHz 


Min 
Max 
Min 
Max 
Notes*t 


105 
2000 
70 
1000 
105 
2000 
70 
1000 
20 
10 
20 
15 
5 - 
TcPC 
PCLK Cycle Time ------------- 250 - 
4000 -- 165 - 
2000 


6 
TsA(WR) 
Address to WR l Setup Time 
80 
80 


7 
ThA(WR) 
Address to WR t Hold Time 
0 
0 


8 
TsA(RD) 
Address to RD l Setup Time 
80 
80 


9 
ThA(RD) 
Address to RD t Hold Time 
0 
0 
lO-TsIA(PC)--- INTACK to PCLK t Setup Time -------- 0 
0 
200 
160 
0 
0 


11 
TsIAi(WR) 
INTACK to WR l Setup Time 
12 
ThIA(WR) 
1NfACK to WR t Hold Time 
. 13 
TsIAi(RD) 
INTACK to RD l Setup Time 
200 
160 


14 
ThIA(RD) 
INTACK to RD t Hold Time 
0 
0 
15-ThIA(PC)--INTACK to PCLK t Hold Time-------- 100 
100 


16 
TsCEl(WR) 
CE Low to WR l Setup Time 
0 
0 


17 
ThCE(WR) 
CE to WR t Hold Time 
0 
0 


18 
TsCEh(WR) 
CE High to WR l Setup Time 
100 
70 


19 
TsCEl(RD) 
CE Low to RD l Setup Time 
0 
0 
1 


20 - 
ThCE(RD)-- CE to RD t Hold Time ----------- 0 
0 
1- 


100 
70 
1 


390 
250 
1 
21 
TsCEh(RD) 
CE High to RD l Setup Time 
22 
TwRDl' 
RD Low Width 
23 
TdRD(DRA) 
RD l to Read Data Active Delay 
0 
0 


24 
TdRDr(DR) 
RD t to Read Data Not Valid Delay 
0 
0 


25 
TdRDf(DR) 
RD l to Read Data Valid Delay 
250 
180 


26 
TdRD(DRz) 
RD t to Read Data Float Delay 
70 
45 
2 


NOTES: 
1. Parameter does not apply to Interrupt Acknowledge 
transactions. 
in the output with a maximum dc load and minimum ac load. 


• Timings are preliminary and subject to change. 
2. Float delay is defined as the time required for a ± 0.5 V change 
r Units in nanoseconds (ns). 


424 
2023-006 


Interrupt 
Aclmowlodgo 
PCLK 
Timing 


Reset 
Timing 


Cyclo 
Timing 


00-07 -----------t------++--~ 


lEI 


lEO 


r------------------------~/J~'----------~ 
CE 
I 
\ 


j "\ 
~ 
-. --~ 
®~--r--'------ 
.--- 
\ 
. 
.,,....----~ 
no or an 
'--________ ---' 
'--__________ __ 


4 MHz 
6 MHz 
No. 
Symbol 
Parameter 
Min 
Max 
Min 
Max 
Notes*t 


27 
TdA(DR) 
Address Required Valid to Read Data Valid Delay 
590 
420 


28 
TwWRl 
WR Low Width 
390 
250 


29 
TsDW(WR) 
Write Data to WR 1 Setup Time 
0 
0 
30 
ThDW(WR) 
Write Data to WR I Hold Time 
0 
0 


31-TdWR(W)--WR 1 to Wait Valid Delay------------- 240 
200 ---4- 
32 
TdRD(W) 
RD 1 to Wait Valid Delay 
240 
200 


33 
TdWRf(REQ) 
WR 1 to W/REQ Not Valid Delay 
240 
200 


34 
TdRDf(REQ) 
RD 1 to W/REQ Not Valid Delay 
240 
200 


35 
TdWRr(REQ) 
WR I to DTR/REQ Not Valid Delay 
5TcPC. 
5TcPC 
+300 
+250 
36- TdRDr(REQ)- RD I to DTR/REQ Not Valid Delay --------- 5TcPC 
5TcPC 
+300 
+250 


37 
TdPC(INT) 
PCLK 1 to INT Valid Delay 
500 
500 


38 
TdIAi(RD) 
INTACK to RD 1 (Acknowledge) Delay 
250 
250 


39 
TwRDA 
RD (Acknowledge) Width 
285 
250 


40-TdRDA(DR)-- RD 1 (Acknowledge) to Read Data Valid Delay------ 190 
180 


41 
TsIEI(RDA) 
lEI to RD 1 (Acknowledge) Setup Time 
120 
100 


42 
ThlEl(RDA) 
lEI to RD I (Acknowledge) Hold Time 
0 
0 


43 
TdIEI(IEO) 
lEI to lEO Delay Time 
120 
100 


44 
TdPC(IEO) 
PCLK I to lEO Delay 
250 
250 


4 


4 
5 


45 - 
TdRDA(INT) - 
RD 1 to INT Inactive Delay ------------ 500 ----:---- 500 --- 4 - 
46 
TdRD(WRQ) 
RD I to WR 1 Delay for No Reset 
47 
TdWRQ(RD) 
WR I to RD 1 Delay for No Reset 
48 
TwRES 
WR and RD Coincident Low for Reset 
49 
Tre 
Valid Access Recovery Time 


NOTES: 
3. Parameter applies only between transactions involving the SCC. 
4. Open·drain output, measured with open-drain test load. 
5. Parameter is system dependent. For any SCC in the daisy 
chain, TdIAi(RD) must be greater than the sum of TdPC(lEO) 
for the highest priority device in the daisy chain, TsIEI(RDA) 


2023-007,008, 009 


30 
30 
250 
6TcPC 
+200 


15 
30 
250 
6TcPC 
+ 130 
3 


for the sec, and TdIEIf(IEO) for each device separating them 
in the daisy chain . 


• Timings are preliminary and subject to change. 
r Units in nanoseconds (ns). 
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General 
Timing 


426 


PCLK 


W/REQ 
REQUEST 


WAIT 
W/REQ ________ ~~~~:t----------_=~----- 


RTxC, TRxC 


RECEIVE _____ 
----:::--;-_ 


RxD ------, 


EXTERNAL 
SYNC ______ -'~ _____ ~~:t--------- 


TRxC,RTxC 


TRANSMIT 


T:::--~~ ~=~------== 


o~::: 
\ {;;:r;) ____ ~'------'~ 


\ 
~ 
'------' 


CTS,DCD,RI ________________ ~ 
______________________ _ 


~:~~ -------------~ 


2016·014 


4 MHz 
6 MHz 
No. 
Symbol 
Parameter 
Min 
Max 
Min 
Max 
Notes*t 


1 
TdPC(REQ) 
PCLK I to W/REQ Valid Delay 
250 
250 


2 
TdPC(W) 
PCLK I to Wait Inactive Delay 
350 
350 


3 
TsRXC(PC) 
RxC t to PCLK t Setup Time (PCLK -;- 4 case only) 
80 
TwPCI 
70 
TwPC1 
1,4 


4 
TsRXD(RXCr) 
RxD to RxC t Setup Time (Xl Mode) 


5 - 
ThRXD(RXCr) - 
RxD to RxC t Hold Time (Xl Mode) 


6 
TsRXD(RXCf) 
RxD to RxC I Setup Time (Xl Mode) 


7 
ThRXD(RXCf) 
RxD to RxC I Hold Time.(Xl Mode) 


8 
TsSY(RXC) 
SYNC to RxC t Setup Time 


9 
ThSY(RXC) 
SYNC to RxC t Hold Time 


10 - 
TsTXC(PC) -- TxC I to PCLK t Setup Time 


11 
TdTXCf(TXD) 
TxC I to TxD Delay (Xl Mode) 


12 
TdTXCr(TXD) 
TxC t to TxD Delay (Xl Mode) 


13 
TdTXD(TRX) 
TxD to TRxC Delay (Send Clock Echo) 


14 
TwRTXh 
RTxC High Width 


15 - 
TwRTXl--- RTxC Low Width 


16 
TcRTX 
RTxC Cycle Time 


17 
TcRTXX 
Crystal Oscillator Period 


18 
TwTRXh 
TRxC High Width 


19 
TwTRXl 
TRxC Low Width 


20-TcTRX 
TRxC Cycle Time 


21 
TwEXT 
DCD or CTS Pulse Width 


22 
TwSY 
SYNC Pulse Width 


NOTES: 
1. RxC is RTxC or TRxC, whichever is supplying the receive 
clock. 
2. TxC is TRxC or RTxC, whichever is supplying the transmit 
clock. 
3. Both RTxC and SYNC have 30 pF capacitors to ground con- 


nected to them. 
4. Parameter applies only if the data rate is one-fourth the PCLK 


rate. In all other cases, no phase relationship between RxC and 
PCLK or TxC and PCLK is required. 


a 
a 
1 


150 
150 
1- 
a 
a 
1,5 


150 
150 
1,5 


-200 
-200 
1 


3TcPC 
3TcPC 
+200 
+200 
. 1 
a 
a 
2,4- 


300 
230 
2 


300 
230 
2,5 


200 
200 


180 
180 
6 


180 
180 
6- 


400 
400 
6 


250 
1000 
250 
1000 
3 


180 
180 
6 


180 
180 
6 


400 
400 
6- 


200 
200 


200 
200 


5. Parameter applies only to FM encoding/decoding. 
6. Parameter applies only for transmitter and receiver; DPLL and 
baud rate generator timing requirements are identical to chip 
PCLK requirements. 


• Timings are preliminary and subject to change. 
t Units in nanoseconds (ns). 
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lSI 
00 
en 
W 
0 
fa R 


System 
Timing 


No. 
Symbol 


TdRXC(REQ) 


2 
TdRXC(W) 


3 
TdRXC(SY) 


4 
TdRXC(INT) 


RTxC, TRxC 


RECEIVE 


W/REQ 
REQUEST 


W/REQ 


WAIT 


SYNC 


OUTPUT 


RTxC,TRxC 


TRANSMIT 


W/REQ 
REQUEST 


W/REQ 


WAIT 


DTR/REQ 
REQUEST 


SYNC 
INPUT 


·INT 


______________________ -+ __________ -J 


______________________ -+ __________ -J 


~K 


l( 
f---W-- 


\ 


10 


4MHz 
Parameter 
Min' 
Max 


RxC I to W IREQ Valid Delay 
8 
12 


RxC I to Wait Inactive Delay 
8 
12 


RxC I to SYNC Valid Delay 
4 
7 


RxC I to INT Valid Delay 
10 
16 


6MHz 
Min 
Max 


8 
12 


8 
12 


4 
7 


"- 
10 
16 


Notes*t 


2 


1,2 


2 


1,2 
5-TdTXC(REQ)-TxC I to W/REQ Valid Delay 
5--8 
5--8 ----3- 


6 
TdTXC(W) 
TxC I to Wait Inactive Delay 


7 
TdTXC(DRQ) 
TxC I to DTR/REQ Valid Delay 


8 
TdTXC(INT) 
TxC I to INT Valid Delay 


9 
TdSY(INT) 
SYNC Transition to INT Valid Delay 


10 
TdEXT(INT) 
DCD or CTS Transition to INT Valid Delay 


NOTES: 
I. 'Open-drain output, measured with open-drain test load. 
2. RxC is RTxC or TRxC, whichever is supplying the receive 
clock. 
3. TxC is THxC or RTxC, whichever is supplying the transmit 
clock. 
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5 
8 
5 
8 


4 
.7 
4 
7 


6 
10 
6 
10 


2 
6 
2 
6 


2 
6 
2 
6 


* Timings are preliminary and subject to change. 
t Units equal to TePC. 


1,3 
3 ' 


1,3 
1 


2016-015 


Ordering 
Product 
Package/ 
Product 
Package/ 
Information 
Number 
Temp 
Speed 
Description 
Number 
Temp 
Speed 
Description 


Z8530 
CE 
4.0 MHz 
SCC (40-pin) 
Z8530A 
CE 
6.0 MHz 
SCC (40-pin) 


Z8530 
CM 
4.0 MHz 
Same as above 
Z8530A 
CM 
6.0 MHz 
Same as above 


Z8530 
CMB 
4.0 MHz 
Same as above 
Z8530A 
CMB 
6.0 MHz 
Same as above 


Z8530 
CS 
4.0 MHz 
Same as above 
Z8530A 
CS 
6.0 MHz 
Same as above 


Z8530 
DE 
4.0 MHz 
Same as above 
Z8530A 
DE 
6.0 MHz 
Same as above 


Z8530 
DS 
4.0 MHz 
Same as above 
Z8530A 
DS 
6.0 MHz 
Same as above 


Z8530 
PE 
4.0 MHz 
Same as above 
Z8530A 
PE 
6.0 MHz 
Same as above 


Z8530 
PS 
4.0 MHz 
Same as above 
Z8530A 
PS 
6.0 MHz 
Same as above 


NOTES: C = Ceramic, D = Cerciip, P = Plastic; E = -40°C to +85°C, M = -55°C to 125°C, MB = -55°C to 125°C with MIL-STD-883 
with Class B processing, S = O°C to + 70°C. 


QO·2023'()3 
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Zilog 


Features 


General 
Description 


2244·001. 002 


[l Two independent, 0 to 1M bit/second, full- 
duplex channels, each with a separate 
crystal oscillator and baud rate generator. 


C Programmable for NR2, NR2I, or FM data 
encoding. 


C Local Loopback and Auto Echo modes. 


The 28531 ASCC Asynchronous Serial 


Communications Controller is a dual-channel, 
multi-protocol data communications peripheral 
designed for use with conventional non- 
multiplexed buses. The ASCC functions as a 
serial-to-parallel, parallel-to-serial con- 
verter/controller. The device contains a variety 
of new, sophisticated internal functions in- 
cluding on-chip baud rate generators and 
crystal oscillators that dramatically reduce the 
need for external logic. 


D7 
TxDA 
} SERIAL 


D6 
RxDA 
DATA 


Ds 
TRxCA 
} CHANNEL 


D4 
RTxCA 
CLOCKS 
DATA BUS 
RiA 
D3 


D2 
CHANNEL 


D1 
DTRlREQA 
CONTROLS 


Do 
RTSA 
FOR MODEM, 


BUS { 
AD 
DMA,OR 
CTSA 
OTHER 
TIMING 


DCDA 
AND RESET 


CONTROL { 


TxDB 
} SERIAL 


RxDB 
DATA 


TRxCB 
} CHANNEL 


INTERRUPTI 


iNr 
RTxCB 
CLOCKS 


INTACK 
RiB 


lEI 
W/REQB 
CHANNEL 


lEO 
DTRlREQB 
CONTROLS 


RTSB 
FOR MODEM, 
DMA,OR 


Z8531 
CTSB 
OTHER 
Asec 
DCDB 
t t t 


+5V GND PCLK 


Figure 1. Pin Functions 


Z8531 ASCC 
Asynchronous Serial 
. (CaDmmmmlUlImn«:a.lnans fC~Btlftro!!ert 


CH·A 


CH·B 


Product 
Specification 


September 1983 


m Asynchronous communications with five to 
eight bits per character and one, one and 
one-half, or two stop bits per character; pro- 
grammable clock factor; break detection 
and generation; parity, overrun, and 
framing error detection. 


The ASCC also has facilities for modem con- 
trols in both channels. In applications where 
these controls are not needed, the modem con- 
trols can be used for general-purpose I/O. 


The 2-BUS daisy-chain interrupt hierarchy is 
also supported-as is standard for 2ilog 
peripheral components. 
The 28531 ASCC is packaged in a 40-pin 


ceramic DIP and uses a single + 5 V power 
supply. 
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The following section describes the pin 


functions of the ASCC. Figures 1 and 2 detail 
the respective pin functions and pin 
assignments. 
AlB. Channel A/Channel B Select (input). 
This signal selects the channel in which the 
read or write operation occurs. 


CEo Chip Enable (input, active Low). This 
signal selects the ASCC for a read or write 
operation. 
CTSA, CTSB. Clear To Send (inputs, active 
Low). If these pins are programmed as Auto 
Enables, a Low on the inputs enables the 
respective transmitters. If not programmed as 
Auto Enables, they may be used as general- 
purpose inputs. Both inputs are Schmitt-trigger 
buffered to accommodate slow rise-time inputs. 
The ASCC detects pulses on these inputs and 
can interrupt the CPU on both logic level 
transitions. 
D/C. Data/Control Select (input). This signal 
defines the type of information transferred to 
or from the ASCC. A High means data is 
transferred; a Low indicates a command. 
DCDA, DCDB. Data Carrier Detect (inputs, 
active Low). These pins function as receiver 
enables if they are programmed for Auto 
Enables; otherwise they may be used as 
general-purpose input pins. Both pins are 
Schmitt-trigger buffered to accomodate slow 
rise-time signals. The ASCC detects pulses on 
these pins and can interrupt the CPU on both 
logic level transitions. 
Do-D'. Data Bus (bidirectional, 3-state). These 
lines carry data and commands to and from 
the ASCC. 
DTR/REQA, DTR/REQB. Data Terminal 
Ready/Request (outputs, active Low). These 
outputs follow the state programmed into the 
DTR bit. They can also be used as general- 
purpose outputs or as Request lines for a DMA 
controller. 
lEI. Interrupt Enable In (input, active High). 
lEI is used with IEO to form an interrupt daisy 
chain when there is more than one interrupt- 
driven device. A High IEI indicates that no 
other higher priority device .has an interrupt 
under service or is requesting an interrupt. 
lEO. Interrupt Enable Out (output, active . 
High). lEO is High only if lEI is High and the 
CPU is not servicing an ASCC interrupt or the 
ASCC is not requesting an interrupt (Interrupt 
Acknowledge cycle only). lEO is connected to 
the next lower priority device's IEI input and 
thus inhibits interrupts from lower priority 
devices. 


INT. Interrupt Request (output, open-drain, 
active Low). This signal is activated when the 
ASCC requests an interrupt. 


INTACK. Interrupt Acknowledge (input, active 
Low). This signal indicates an active Interrupt 
Acknowledge cycle. During this cycle, the 
ASCC interrupt daisy chain settles. When RD 
becomes active, the ASCC places an interrupt 
vector on the data bus (if IEI is High). 
INTACK is latched by the rising edge 
of PCLK. 


PCLK. Clock (input). This is the master ASCC 
clock used to synchronize internal signals; 
PCLK is a TTL level signal. 


RD. Read (input, active Low). This signal indi 
cates a read operation and when the ASCC is 
selected, enables the ASCC's bus drivers. 
During the Interrupt Acknowledge cycle, this 
signal gates the interrupt vector onto the bus 
if the ASCC is the,highest priority device 
requesting an interrupt. 
RxDA, RxDB. Receive Data (inputs, active 
High). These input signals receive serial data 
at standard TTL levels. 


RIA, RIB. Ring Indicator (inputs, active Low). 
These pins can act either as inputs, or part of 
the crystal oscillator circuit. In normal mode 
(crystal oscillator option not selected), these 
pins are inputs similar to CTS and DCD. In 
this mode, transitions on these lines affect the 
state of the Ring Indicator status bits in Read 
Register 0 (Figure 8) but have no other func- 
tion. 
RTxCA, RTxCB. Receive/Transmit Clocks 
(inputs, active Low). These pins can be pro- 
grammed in several different modes of opera- 
tion. In each channel, RTxC may supply the 
receive clock, the transmit clock, the clock for 
the baud rate generator, or the clock for the 
Digital Phase-Locked Loop. These pins can 
also be programmed for use with the respec- 
tive HI pins as a crystal oscillator. The receive 
clock may be 1, 16,32, or 64 times the data 
rate in Asynchronous modes. 
RTSA, RTSB. Request To Send (outputs, 
active Low). When the Request To Send (RTS) 
bit in Write Register 5 (Figure 9) is set, the 
RTS signal goes Low. When the RTS bit is 
reset in the Asynchronous mode and Auto 
Enable is on, the signal goes High after the 
transmitter is empty. With Auto Enable off, the 
RTS pin strictly follows the state of the RTS bit. 
Both pins can he used as general-purpose 
outputs. 
TxDA, TxDB. Transmit Data (outputs, active 
High). These output signals transmit serial data 
at standard TTL levels. 


TRxCA, TRxCB. Transmit/Receive Clocks 
(inputs or outputs, active Low). These pins can 
be programmed in several different modes of 
operation. TRxC may supply the receive clock 
or the transmit clock in the input mode or sup- 
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ply the output of the Digital Phase-Locked 
Loop, the crystal oscillator, the baud rate 
generator, or the transmit clock in the output 
mode. 


WR. Write (input, active Low). When the 
ASCC is selected, this signal indicates a write 
operation. The coincidence of RD and WR is 
interpreted as a reset. 


The functional capabilities of the ASCC 


can be described from two different points 
of view: as a data communications device, 
it transmits and receives data in a wide 
variety of data communications protocols; as a 
microprocessor peripheral, the ASCC offers 
valuable features such as vectored interrupts, 
polling, and simple handshake capability. 


Data Communications Capabilities. The 
ASCC provides two independent full-duplex 
channels programmable for use in any com- 
mon Asynchronous data communication pro- 
tocol. Figure 3 and the following description 
briefly detail this protocol. 
Asynchronous Modes. Transmission and 
reception can be accomplished independently 
on each channel with five to eight bits per 
character, plus optional even or odd parity. 
The transmitters can supply one, one-and-a- 
half, or two stop bits per character and can 
proVide a break output at any time. The 
receiver break-detection logic interrupts the 
CPU both at the start and at the end of a 
received break. Reception is protected from 
spikes by a transient spike-rejection 
mechanism that checks the signal one-half a 
bit time after a Low level is detected on the 
receive data input (RxDA or RxDB in 
Figure 1). 1£ the Low does not persist (as in the 
case of a transient), the character assembly 
process does not start. 
Framing errors and overrun errors are 
detected and buffered together with the partial 
character on which they occur. Vectored inter- 
rupts allow fast servicing of error conditions 
using dedicated routines. Furthermore, a 
built-in checking process avoids the interpreta- 
tion of a framing error as a new start bit: a 
framing error results in the addition of one-half 
a bit time to the point at which the search for 
the next start bit begins. 
The ASCC does not require symmetric 
transmit and receive clock signals-a feature 
allowing use of the wide variety of clock 
sources. The transmitter and receiver can 


PARITY 


STrT 
llOP 


W/REQA. W/REQB. Waif/Request (outputs, 
open-drain when programmed for aWait func- 
tion, driven High or Low when programmed 
for a Request function). These dual-purpose 
outputs may be programmed as Request lines 
for a DMA controller or as Wait lines to syn- 
chronize the CPU to the A$CC data rate. The 
reset state is Wait. 


handle data at a rate of 1116, 1132, or 1164 of 
the clock rate supplied to the receive and 
transmit clock inputs. 


Baud Rate Generator. Each channel in the 
ASCC contains a programmable baud rate 
generator. Each generator consists of two 8-bit 
time constant registers that form a 16-bit time 
constant, a 16-bit down counter, and a flip-flop 
on the output producing a square wave. On 
startup, the flip-flop on the output is set in a 
High state, the value in the time constant 
register is loaded into the counter; and the 
counter starts counting down. The output of 
the baud rate generator toggles upon reaching 
0, the value in the time constant register is 
loaded into the counter, and the process is 
repeated. The time constant may be changed 
at any time,. but the new value does not take 
effect until the next load of the count~r. 


The ~utput of the baud rate generator may 
be used as either the transmit clock, the 
receive clock, or both. It can also drive the 
Digital Phase-Locked Loop (see next section). 
If the receive clock or transmit clock is not 
programmed to come from the TRxC pin, the 
output of the baud rate generator may be 
echoed out via the TRxC pin. 
The following formula relates the time con- 
stant to- the baud rate (the baud rate is in 
bits/second and the BR clock period is in 
seconds): 


time constant = 
PCLK 
-2 
2 (clock factor) (baud) 


Digital Phase-Locked Loop. The ASCC con-· 
tainsa Digital Phase-Locked-Loop (DPLL) to 
recover clock information from a data stream 
with NRZI or FM encoding. The DPLL is driven 
by a clock that is nominally 32 (NRZI) or 16 
(FM) times the data rate. The DPLL uses this 
clock, along with the data stream~ to construct 
a clock for the data. This clock may then be 
used as the ASCC receive clock, the transmit 
clock, or both. 
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Figure 3. ASCC Protocol 
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For NRZI encoding, the DPLL counts the 32x 
clock to create nominal bit times. As the 32x 
clock is counted, the DPLL is searching the 
incoming data stream for edges (either 1 to 0 
or 0 to 1). Whenever an edge is detected, the 
DPLL makes a count adjustment (during the 
next counting cycle), producing a terminal 
count closer to the center of the bit cell. 
For FM encoding, the DPLL still counts from 
o to 31, but with a cycle corresponding to two 
bit times. When the DPLL is locked, the clock 
edges in the data stream should occur between 
counts 15 and 16 and between counts 31 and 
O. The DPLL looks for edges only during a 
time centered on the 15 to 16 counting 
transition. 
The 32x clock for the DPLL can be pro- 
grammed to come from either the RTxC input 
or the output of the baud rate generator. The 
DPLL output may be programmed to be 
echoed out of the ASCC via the TRxC pin (if 
this pin is not being used as an input). 


Data Encoding. The ASCC may be pro- 
grammed to encode and decode the serial data 
in four different ways (Figure 4). In NRZ 
encoding, a 1 is represented by a High level 
and a 0 is represented by a Low level. In NRZI 
encoding, a. 1 is represented by no change in 
level and a 0 is represented by a change in 
leveL In FMl (more properly, bi-phase mark), 
a transition occurs at the beginning of every 
bit cell. A 1 is represented by an additional 
transition at the center of the bit cell and a 0 is 
represented by no additional transition at the 
center of the bit cell. In FMO (bi-phase space), 
a transition occurs at the beginning of every 
bit cell. A 0 is represented by an additional 
transition at the center of the bit cell, and a 1 
is represented by no additional transition at 
the center of the bit cell. In addition to these 
four methods, the ASCC can be used to 
decode Manchester (bi-phase level) data by 
using the DPLL in the FM mode and program- 
ming the receiver for NRZ data. Manchester 
encoding always produces a transition at the 
center of the bit cell. If the transition is 0 to J, 
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the bit is a O. If the transition is 1 to 0, the bit 
is a 1. 


Auto Echo and Local Loopback. The ASCC is 
capable of automatically echoing everything it 
receives. In Auto Echo mode, RxD is con- 
nected to TxD internally. Auto Echo mode can 
be used with .NRZI or FM encoding with no 
additional delay, because the data stream is 
not decoded before retransmission. In Auto 
Echo mode, the CTS input is ignored as a 
transmitter enable (although transitions on this 
input can still cause interrupts if programmed 
to do so). In this mode, the transmitter is 
actually bypassed and the programmer is 
responsible for disabling transmitter interrupts 
and WAIT/REQUEST on transmit. 
The ASCC is also capable of local 100pback. 


In this mode TxD is connected to RxD .intern- 
ally, just as in Auto Echo mode. Bowever, in 
Local Loopback mode, the internal transmit 
data is tied to the internal receive data and 
RxD is ignored (except to be echoed out via 
TxD). The CTS and DCD 
inputs are also ignored as transmit and receive 
enables. However, transitions on these inputs 
can still cause interrupts. Local Loopback 
works with NRZ, NRZI or FM coding of the data 
stream. 


1/0 Interface Capabilities. The ASCC offers 
the choice of Polling, Interrupt (vectored or 
nonvectored), and Block Transfer modes to 
transfer data, status, and control information to 
and from the CPU. The Block Transfer mode 
can be implemented under CPU or DMA 
control. 


Polling. All interrupts are disabled. Three 
status registers in the ASCC are automatically 
updated whenever any function is performed. 
The idea behind polling is for the CPU to 
periodically read a status register until the 
register contents indicate the need for data to 
be transferred. Only one register needs to be 
read; depending on its contents, the CPU 
either writes data, reads data, or continues. 
Two bits in the register indicate the need for 


I 
\ 


I 
\ 


Figure 4. Data Encoding Methods 


2016·002 


Functional 
Description 
(Continued) 


2016-003 


data transfer. An alternative is a poll of the 
Interrupt Pending register to determine the 
source of an interrupt. The status for both 
channels resides in one register. 


Interrupts. When an ASCC responds to an 
Interrupt Acknowledge signal (INTACK) from 
the CPU, an interrupt vector may be placed on 
the data bus. This vector is written in WR2 and 
may be read in RR2A or RR2B (Figures 8 
and 9). 
To speed interrupt response time, the ASCC 


can modify three bits in this vector to indicate 
status. If the vector is read in Channel A, 
status is never included; if it is read in 
Channel B, status is always included. 
Each of the six sources of interrupts in the 


ASCC (Transmit, Receive, and External/Status 
interrupts in both channels) has three bits 
associated with the interrupt source: Interrupt 
Pending (IP), Interrupt Under Service (IUS), 
and Interrupt Enable (IE). Operation of the IE 
bit is straightforward. If the IE bit is set for a 
given interrupt source, then that source can 
request interrupts. The exception is when the 
MIE (Master Interrupt Enable) bit in WR9 is 
reset and no interrupts may be requested. The 
IE bits are write only. 
The other two bits are related to the inter- 


rupt priority chain (Figure 5). As a 
microprocessor peripheral, the ASCC may 
request an interrupt only when no higher 
priority device is requesting one, e.g., when 
lEI is High. If the device in question requests 
an interrupt, it pulls down INT. The CPU then 
responds with INTACK, and the interrupting 
device places the vector on the data bus. 
In the ASCC, the IP bit signals a need for 
interrupt servicing. When an IP bit is 1 and 
the IEI input is High, theINT output is pulled 
Low, requesting an interrupt. In the ASCC, if 
the IE bit is not set by enabling interrupts, 
then the IP for that source can never be set. 
The IP bits are readable in RR3A. 
The IUS bits signal that an interrupt request 
is being serviced. If an IUS is set, all interrupt 
sources of lower priority in the ASCC and 
external to the ASCC are prevented from 
requesting interrupts. The internal interrupt 
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sources are inhibited by the state of the inter- 
nal daisy chain, while lower priority devices 
are inhibited by the IEO output of the ASCC 
being pulled Low and propagated to subse- 
quent peripherals. An IUS bit is set during an 
Interrupt Acknowledge cycle if there are no 
higher priority devices requesting interrupts. 
There are three types of interrupts: 
Transmit, Receive, and External/Status. Each 
interrupt type is enabled under program con- 
trol with Channel A having higher priority 
than Channel B, and with Receiver, Transmit, 
and External/Status interrupts prioritized in 
.that order within each channel. When the 
Transmit interrupt is enabled, the CPU is 
interrupted when the transmit buffer becomes 
empty. (This implies that the transmitter must 
have had a data character written into it so 
that it can become empty.) When enabled, the 
receiver can interrupt the CPU in one of three 
ways: 


[J Interrupt on First Receive Character or 


Special Receive Condition. 


[J Interrupt on All Receive Characters or 


Special Receive Condition. 


[J Interrupt on SpeCial Receive Condition 


Only. 
Interrupt on First Character or Special Con- 


dition and Interrupt on Special Condition Only 


r are typically used with the Block Transfer 
mode. A Special Receive Condition is a 
,receiver overrun, and, optionally, a parity 
error. The Special Receive Condition interrupt 
is different from an ordinary receive character 
available interrupt only in the status placed in 
the vector during the Interrupt Acknowledge 
cycle. In Interrupt on First Receive Character, 
an interrupt can occur from Special Receive 
Conditions any time after the first receive 


, character interrupt. 
The main function of the External/Status 
interrupt is to monitor the signal transitions of 
the CTS, DCD, and RI pins; however, an 
External/Status interrupt is also caused by a 
Transmit Underrun condition, or a zero count 
in the baud rate generator, or by the detection 
of a Break. 
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Figure S. Interrupt Schedule 
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CPU/DMA Block Transfer. The ASCC pro- 
vides a Block Transfer mode to accommodate 
CPU block transfer functions and DMA con- 
trollers. The Block Transfer mode uses the 
WAITI REQUEST output in conjunction with 
the WaiVRequest bits in WRl. The WAITI 
REQUEST output can be defined under soft- 
ware control as a WAIT line in the CPU Block 
Transfer mode or as a REQUEST line in the 


The ASCC internal structure includes 
two full-duplex channels, two baud rate 
generators,. internal control and interrupt 
logiC, and a bus interface to a nonmultiplexed 
bus. Associated with each channel are a 
number of read and write registers for mode 
control and status information, as well as logic 
necessary to interface to modems or other 
external devices (Figure 6). 
The logic for both channels provides 
formats, synchronization, and validation for 
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DMA Block Transfer mode. 
To a DMA controller, the ASCC REQUEST 


output indicates that the ASCC is ready to 
transfer data to or from memory. To the CPU, 
the WAIT line indicates that the ASCC is not 
ready to transfer data, thereby requesting that 
the CPU extend the 1/0 cycle. The DTRI 
REQUEST line allows full-duplex operation 
under DMA control. 


data transferred to and from the channel inter- 
face. The modem control inputs are monitored 
by the control logic under program control. 
All of the modem control signals are general- 
purpose in nature and can optionally be used 
for functions other than modem control. 
The register set for each channel includes 
ten control (write) registers, and four status 
(read) registers. In addition, each baud rate 
generator has two (read/write) registers for 
holding the time constant that determines the 
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Architecture 
(Continued) 
baud rate. Finally, associated with the inter- 
rupt logic is a write register for the interrupt 
vector accessible through either channel, a 
write only Master Interrupt Control register 
and three read registers: one containing the 
vector with status infomation (Channel B only), 
one containing the vector without status 
(Channel A only), and one containing the 
Interrupt Pending bits (ChannelA only). 
The registers for each channel are 
designated as follows: 


WRO-WR 15 - 
Write Registers 0-5, 8-15. 


RRO-RR3, RRlO, RRI2, RRI3, RR15 - 
Read 
Registers 0 through 3, 10, 12, 13, 15. 


Table 1 lists the functions assigned to each 
read or write register. The ASCC contains on- 
ly one WR2 and WR9, but they can be access- 
ed by either channel. All other registers are 
paired (one for each channel). 


Data Path. The transmit and receive data path 
illustrated in Figure 7 is identical for both 
channels. The receiver has three 8-bit buffer 
registers in an FIFO arrangement, in addition 
to the 8-bit receive shift register. This scheme 
creates additional time for the CPU to service 
an interrupt at the beginning of a block of 
high speed data. Incoming data is routed 
through one of. seve~al paths depending on the 
selected mode (the character length also deter- 
mines the data path). 
The transmitter has an 8-bit Transmit Data 
buffer register loaded from the internal data 
bus and an ll-bit Transmit Shift register that 
can be loaded from the Transmit Data register. 


Programming 
The ASCC contains 11 write registers in 
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each channel that are programmed by the 
system separately to configure the functional 
personality of the channels. 
In the ASCC, register addressing is direct 
for the data registers only, which are selected 
by a High on the DIe pin. In all other cases 
(with the exception of WRO andRRO), pro- 
gramming the write registers requires two 
write operations and reading the read registers 
requires both a write and a read operation. 
The first write is to WRO and contains three 
bits that point to the selected register. The se- 
cond write is the actual control word for the 
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Read Register Functions 


Transmit/Receive buffer status and External status 


Special Receive Condition status 


Modified interrupt vector (Channel B only) 
Unmodified interrupt vector (Channel A only) 


Interrupt Pending bits (Channel A only) 


Receive buffer 


Miscellaneous status 


Lower byte of baud rate generator time constant 


Upper byte of baud rate generator time constant 


RR15 
ExternaVStatus interrupt information 


Write Register Functions 


WRO 
CRC initialize, initialization commands for the 
various modes, Register Pointers. 


WRI 
Transmit/Receive interrupt and data transfer mode 
definition 


WR2 
Interrupt vector (accessed through either channel) 


WR3 
Receive parameters and control 


WR4 
Transmit/Receive miscellaneous parameters and 
modes 


WR5 
Transmit parameters and controls 


WR8 
Transmit buffer 


WR9 
Master interrupt control and reset (accessed 
through either channel) 


WRlO 
Miscellaneous transmitter/receiver control bits 


WRII 
Clock mode control 


WR12 
Lower byte of baud rate generator time constant 


WR13 
Upper byteof baud rate generator time constant 


WRl4 
Miscellaneous control bits 


WR15 
ExternaVStatus interrupt control 


Table I. Read and Write Register Functions 


selected register, and if the second operation 
is read, the selected read register is accessed. 
All of the registers in the ASCC, including the 
data registers, may be accessed in this fashion. 
The pointer bits are automatically cleared after 
the read or write operation so that WRO (or 
RRO) is addressed again. 
The system program first issues a series of 
commands to initialize the basic :mode of 
operation. For example, the character length, 
clock rate, number of stop bits, even or odd 
parity might be set first. Then the interrupt 
mode would be set, and finally, receiver or 
transmitter enable. 
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Read Registers. The ASCC contains eight 
read registers (actually nine, counting the 
receive buffer (RR8) in each channel). Four of 
these may be read to obtain status information 
(RRO, RRl, RRIO, and RR15). Two registers 
(RR12 and RR13) may be read to learn the 
baud rate generator time constant. RR2 con- 
tains either the unmodified interrupt vector 
(Channel A) or the vector modified by status 
information (Channel B). RR3 contains the 
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Read Register 2 


INTERRUPT VECTOR· 
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Read Register 3 
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CHANNELB EXT/STATlp· 
L 
CHANNEL B Tx Ip· 


CHANNEL B Rx Ip· 


CHANNEL A EXT/STAT Ip· 


CHANNEL A Tx Ip· 


CHANNEL A Rx Ip· 
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Interrupt Pending OP) bits (Channel A). 
Figure 8 shows the formats for each read 
register. 
The status bits of RRO and RRI are carefully 
grouped to simplify status monitoring; e.g., 
when the interrupt vector indicates a Special 
Receive Condition interrupt, all the appro- 
priate error bits can be read from a single 
register (RRl). 
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Figure 8. Read Register Bit Functions 
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Write Registers. The ASCC contains 11 write 
registers (12 counting WR8, the transmit 
buffer) in each channel. These write registers 
are programmed separately to configure the 
functional "personality" of the channels. In 
addition, there are two registers (WR2 and 


Write Register 0 


0 
0 
0 
REGISTER 0 


0 
0 
1 
REGISTER 1 


0 
1 o REGISTER 2 


0 
1 
1 
REGISTER 3 


1 
0 
0 
REGISTER 4 


1 
0 
1 
REGISTER 5 


1 
1 o NULL CODE 


1 
1 
1 
NULL CODE 


0 
0 
0 
REGISTER 8 


I· 


0 
0 
1 
REGISTER 9 


0 
1 
0 
REGISTER 10 


0 
1 
1 
REGISTER 11 


1 
0 
0 
REGISTER 12 


1 
0 
1 
REGISTER 13 


1 
1 
0 
REGISTER 14 


1 
1 
1 
REGISTER 15 


o 0 
0 
NULL CODE 


o 0 
1 
POINT HIGH 


o RESET EXT/STAT INTERRUPTS 


1 
NULL CODE 


o ENABLE INT ON NEXT Rx CHARACTER 


RESET TxlNT PENDING 


1 
0 
ERROR RESET 


1 
RESET HIGHEST IUS 


'WITH POINT HIGH COMMAND 


Write Register 1 


I~I~I~I~I~I~I~I~I 


II L ''''''' 'NAO" 
L 
Tx INT ENABLE 


PARITY IS SPECIAL CONDITION 


o 0 
Rx I~JT C~SA5t.[ 


o 
1 
Rx INT ON FIRST CHARACTER OR SPECIAL CONDITION 


1 
OINT ON ALL Rx CHARACTERS OR SPECIAL CONDITION 


1 
1 
Rx INT ON SPECIAL CONDITION ONLY 
'------- WAIT/DMA REQUEST ON RECEIVEI'I'fiAfiSMJT 
'-------- WAif/DMA REQUEST FUNCTION 
'--------- WAITIDMA REQUEST ENABLE 


Write Register 2 


I~I~I~I~I~I~I~I~I 


~li 
L--________ V7 


INTERRUPT VECTOR 


WR9) shared by the two channels that may be 
accessed through either of them. WR2 contains 
the interrupt vector for both channels, while 
WR9 contains the interrupt control bits. 
Ffgure 9 shows the format of each write 
register. 


Write Register 3 


I~I~I~I~I~I~I~I~I 


~c~~'~"" 


o 
0 
Rx 5 BITS/CHARACTER 


o 
1 
Rx 7 BITS/CHARACTER 


1 
0 
Rx 6 BITS/CHARACTER 


1 
1 
Rx 8 BITS/CHARACTER 


Write Register 4 


I~I~I~I~I~I~I~I~I 


~ 


I L PARITY ENABLE 
L 
PARITY EVEN/ODD 


o 0 
DO NOT PROGRAM 
o 1 
1 STOP BIT/CHARACTER 


1 
0 
1'1. STOP BITS/CHARACTER 


1 
1 
2 STOP BITS/CHARACTER 


o 0 
X 1 CLOCK MODE 
ror;- 
X16 CLOCK MODE 
~ro X32 CLOCK MODE 
!~ X64 CLOCK MODE 


Write Register 5 


I~I~I~I~I~I~I~I~I 


~~;:::~. 


o 
0 
Tx 5 BITS (OR LESS)lCHARACTER 


o 
Tx 7 BITS/CHARACTER 


1 
Tx 6 BITS/CHARACTER 


1 
1 
Tx 8 BITS/CHARACTER 


L--________ DTR 


Figure 9. Write Register Bit Functions 


2244-006 


Programming Write Register 9 
(Continued) 


I~I~I~I~I~I~I~I~I 
~~ 


~~~ 
~DLC 


MIE 


:TATUS HIGH/STATUS LOW 


o 
0 
NO RESET 


o 
1 
CHANNEL RESET B 
o CHANNEL RESET A 


'1 
FORCE HARDWARE RESET 


Write Register 10 


I~I~I~I~I~I~I~I~I 
~; 


o 
0 
NRZ 


o 
1 
NRZI 


1 
0 
FM1 (TRANSITION = 1) 


1 
1 
FMO (TRANSITION = 0) 


Write Register 11 


I~I~I~I~I~I~I~I~I 
1 


0 
0 
TRxC OUT = XTAL OUTPUT 


o 
1 
TRxC OUT = TRANSMIT CLOCK 


1 
0 
TRxC OUT = BR GENERATOR OUTPUT 


1 
1 
TRxC OUT = DPLL OUTPUT 


TRxC o/i 


o 
0 
TRANSMIT CLOCK = RTxC PIN 


o 
1 
TRANSMIT CLOCK = TRxC PIN 


1 
0 
TRANSMIT CLOCK = BR GENERATOR OUTPUT 


1 
1 
TRANSMIT CLOCK = DPLL OUTPUT 


o 0 
RECEIVE CLOCK = RTxC PIN 


o 
1 
RECEIVE CLOCK = TRXC PIN 


1 
0 
RECEIVE CLOCK = BR GENERATOR OUTPUT 


1 
1 
RECEIVE CLOCK = DPLL OUTPUT 


L..-________ RTxC XTAUNO XTAL 


Write Register 12 


I~I~I~I~I~I~I~I~I 


~1l 
L-________ T 
C 
l 


Write Register 13 


I~I~I~I~I~I~I~I~I 


~1j:~ 


L..-________ TC15 


Write Register 14 


I~I~I~I~I~I~I~I~I 


LOWER BYTE OF 
TIME CONSTANT 


UPPER BYTE OF 
TIME CONSTANT 


~ 


I I L BR GENERATOR ENABLE 
~ 
BR GENERATOR SOURCE 


DfR/REQUEST FUNCTION 


AUTO ECHO 


LOCAL LOOPBACK 


0 
0 
0 
NULL COMMAND 


0 
0 
1 
ENTER SEARCH MODE 


0 
1 
RESET MISSING CLOCK 


0 
1 
DISABLE DPLL 


0 
0 
SET SOURCE = BR GENERATOR 


0 
1 
SET SOURCE = RTxC 


1 
1 
0 
SET FM MODE 


1 
1 
1 
SET NRZI MODE 


Write Register 15 


I~I~I~I~I~I~I~I~I 
~~ 


I ~:,""ro"",,, 


CDCDIE 
iii IE 


CTS IE 


1 
L-________ BREAK IE 


Figure 9. Writo Register Bit Functions (Continued) 
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Timing 
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The ASCC generates internal control signals 
from WR and RD that are related to PCLK. 
Since PLCK has no phase relationship with 
WR and RD, the circuitry generating these in- 
ternal control signals must provide time for 
metastable conditions to disappear. This gives 
rise to a recovery time related to PCLK. The 
recovery time applies only between bus tran- 
sactions involving the ASCC. The recovery 
time required for proper operation is specified 
from the rising edge of WR or RD in the first 


transaction involVing the ASCC to the falling 
edge of WR or RD in the second transaction 
involving the ASCC. This time must be at least 
6 PLCK cycles plus 200 ns. 


Read Cycle Timing. Figure 10 illustrates read 
cycle timing, Addresses on NB and Die and 
the status on INTACK must remain stable 
throughout the cycle. If CE falls after RD 
falls,or rises before RD rises, the effective RD 
is shortened. 


AlB, DIC 
X 
ADDRESS VALID 
V-- 
__ 
--J '--_________ 
...... ~ 


\ 


\_-- 
1 


\ ____ --1 


Do-D7 ------------«\. ____ .JX 
DATA VALID »)------ 


Figure 10. Read Cycle Timing 


Write Cycle Timing. Figure 11 illustrates 
write cycle timing. Addresses on NB and Die 
and the status on INTACK must remain stable 


throughout the cycle. If CE falls after WR falls 
or rises before WR rises, the effective WR is 
shortened. 


AlB, DIC 
X 
ADDRESS VALID 
V-- 
_--J _ _ _ _ _ _ _ _ 
~ 


\ 


\ 
I 
,\. _______________ J' 


\_-- 
I 


DO-D7--------~(\. _____ 
D_AT_A_V_AL_ID ____ __J)~----- 


Figure 11. Write Cycle Timing 


Interrupt Acknowledge Cycle Timing. Figure 
12 illustrates interrupt acknowledge cycle tim- 
ing. Between the time INTACK goes low and 
the falling edge of RD,. the internal and exter- 
nal lEI/lEO daisy chains settle. If there is an 
interrupt pending the ASCC and lEI is High 


when RD falls, the acknowledge cycle was in- 
tended for the ASCC. In this case, the ASCC 
may be programmed to respond to RD Low by 
placing its interrupt vector on Do-D7 and sets 
the appropriate Interrupt-Under-Service latch 
internally. 


INTACK~~ _____ ~;~'l~ _______________ -'1' 


I: 
\_------1' 


Do-D7 --------II,-,..'-----«\-___ .JX 
VECTOR »)------- 


Figure 12. Interrupt Acknowledge Cycle Timing 


2023-003, 004, 005 


Absolute 
Maximum 
Ratings 


Standard 
Test 
Conditions 


DC 
Charac- 
teristics 


Capacitance 


8085-006, 001 


Voltages on all inputs and outputs 
with respect to GND .......... -0.3 V to + 7.0 V 
Operating Ambient 
Temperature ................. As Specified in 
Ordering Information 
Storage Temperature ......... -65°C to + 150 °C 


The characteristics below apply for the 
following standard test conditions, unless 
otherwise noted. All voltages are referenced to 
GND. Positive current flows into the refer- 
enced pin. Standard conditions are as follows: 


+5 V 


2.1K 


Figure 13. Standard Test Load 


Symbol 
Parameter 
Min 


VIH 
Input High Voltage 
2.0 


VIL 
Input Low Voltage 
-0.3 
VOH 
Output High Voltage 
2.4 


VOL 
Output Low Voltage 


IlL 
Input Leakage 


IOL 
Output Leakage 


Icc 
Vee Supply Current 


Stresses greater than those listed under Absolute Maxi· 


mum Ratings may cause permanent damage to the device. 
This is a stress rating only; operation of the device at any 
condition above those indicated in the operational sections 
of these specifications is not implied. Exposure to absolute 
maximum rating conditions for extended periods may affect 
device reliability. 


IJ +4.75 V =:;; Vee =:;; +5.25 V 


[J GND = 0 V 


[J TA as specified in Ordering Information 
All ac parameters assume a load capacitance 
of 50 pF max. 


FROM OUTPUT 


UNDER TEST 


+5V 


~ 


2'2K 
. 


I 


50PF 


Figure 14. Open-Drain Test Load 


Max 


Vee +0.3 
0.8 


0.4 


± 10.0 


± 10.0 
250 


Unit 


V 
V 
V 
V 
pA 


pA 


rnA 


Condition 


IoH = -250 pA 
IoL= +2.0 rnA 
0.4 s VIN S + 2.4V 


0.4 S VOUT S +2.4V 


Vee = 5 V ± 5% unless otherwise specified, over specified temperature range. 


Symbol 
Parameter 
Min 
Max 
Unit 
Test Condition 


C1N 
Input Capacitance 
10 
pF 
U nrneasured Pins 
COUT 
Output Capacitance 
15 
pF 
Returned to Ground 
Cvo 
Bidirectional Capacitance 
20 
pF 


f = 1 MHz, over specified temperature range. 
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Read and 
Write 
Timing 


PCLK 
_in-~ ~~lk'- 
:=J< 
~ 
AlB, Die 
. 
J( 
f--<D f-- 
1-----0-~ -j®-4r- 


- 
~~ 
~ 
~~ 
~---® 
:@~ 
~U . 


f--~ 
-®-- 


No. 
Symbol 


Do-Dr 
READ 


Do-Dr 


WRITE 


W/REQ 


WAIT 


W/RI!Q 


REQUEST 


DTR/REQ 
REQUEST 


Parameter 


f--®--\ 


-¥- 
~ 
@- ... H 


17 


®-i- 


21 


15 


i\ 


r--w 


31 


~ 


34 


I 
~1\ 
-® 
) 
11 
-l 
®---I 
-~ ~ 


-' 
-® 


-f-® 
\~ 


J 
- 
--@- 


J 


IJ6' 


37 
.1 


4MHz 
6MHz 
Min 
Max 
Min 
Max 


1 
TwPCl 
PCLK Low Width 
105 
2000 
70 
1000 


2 
TwPCh 
PCLK High Width 
105 
2000 
70 
1000 


3 
TfPC 
PCLK Fall Time 
20 
10 
4 
TrPC 
PCLK Rise Time 
20 
15 


Notes*t 


5-TcPC 
PCLK Cycle Time ------------250 -4000 --165 -2000 ----- 
6 
TsA(WR) 
Address to WR I Setup Time 
80 
80 


7 
ThA(WR) 
Address to WR I Hold Time 
0 
0 


8 
TsA(RD) 
Address to RD I Setup Time 
80 
80 


9 
ThA(RD) 
Address to RD I Hold Time 
0 
0 


lO-TsIA(PC)---INTACK to PCLK I Setup Time 
0 
0 -------- 
11 
TsIAi(WR) 
INTACK to WR I Setup Time 
200 
200 


12 
ThIA(WR) 
INTACK to WR I Hold Time 
0 
0 


13 
TsIAi(RD) 
INTACK to RD I Setup Time 
200 
200 


14 
ThIA(RD) 
INTACK to RD I Hold Time 
0 
0 


15-ThIA(PC)--INTACK to PCLK I Hold Time 
100 
100-------- 
16 
TsCEl(WR) 
CE Low to WR I Setup Time 
0 
0 


17 
ThCE(WR) 
CE to WR I Hold Time 
0 
0 


18 
TsCEh(WR) 
CE High to WR I Setup Time 
100 
70 


19 
TsCEl(RD) 
CE Low to RD I Setup Time 
0 
0 
1 


20 
ThCE(RD) 
CE to RD I Hold Time 
0 
0 
1 
21-TsCEh(RD)--CE High to RD I Setup Time 
100 
70------1- 
22 
TwRDl 
RD Low Width 
390 
250 
1 
23 
TdRD(DRA) 
RD I to Read Data Active Delay 
0 
0 


24 
TdRDr(DR) 
RD I to Read Data Not Valid Delay 
0 
0 


25 
TdRDf(DR) 
RD I to Read Data Valid Delay 
250 
26 
TdRD(DRz) 
RD I to Read Data Float Delay 
70 


180 
45 
2 


NOTES: 
I. Parameter does not apply to Interrupt Acknowledge 
transactions. 


2. Float delay is defined as the time required for a ± 0.5 V change 
in the output with a maximum dc load and minimum ac load. 


• Timings are preliminary and subject to change. 
t Units in nanoseconds (ns). 
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2023-006 


Interrupt 
Acknow ledge 
Timing 


Reset 
Timing 


Cycle 
Timing 


PCLK 


DO-D7--------------------~----------~H_~~ 


lEI 


lEO 
.~--- 


CE ______ -JJ'~--------------------------~f~F(----------~ ~ ________________ __ 
~ 
t--------_ 
®~--~---~~(------~~~~~~~ 


RDorWR ------" 
~~ 
__________ J( 
~\ 


4MHz 
6MHz 
No. 
Symbol 
Parameter 
Min 
Max 
Min 
Max 
Notes*t 


27 
TdA(DR) 
Address Required Valid to Read Data Valid Delay 
590 
420 


28 
TwWRl 
WR Low Width 
390 
250 


29 
TsDW(WR) 
Write Data to WR I Setup Time 
0 
0 
30 
ThDW(WR) 
Write Data to WR 1 Hold Time 
0 
0 


31 -TdWR(W)---WR I to Wait Valid Delay ------------- 240 
200 ----4- 
200 
200 
200 


240 
240 
240 


32 
TdRD(W) 
RD I to Wait Valid Delay 
33 
TdWRf(REQ) 
WR I to W/REQ Not Valid Delay 
34 
TdRDf(REQ) 
RD I to W/REQ Not Valid Delay 


4 


35 
TdWRr(REQ) 
WR 1 to DTR/REQ Not Valid Delay 
5TcPC 
5TcPC 
+300 
+250 


36-TdRDr(REQ)--RD 1 to DTR/REQ Not Valid Delay--------- 5TcPC 
5TcPC 
+300 


37 
TdPC(INT) 
PCLK I to INT Valid Delay 
500 


38 
TdIAi(RD) 
IN TACK to RD I (Acknowledge) Delay 
39 
TwRDA 
RD (Acknowledge) Width 
285 


+250 
500 


250 


4 
5 


40 -TdRDA(DR)--RD I (Acknowledge) to Read Data Valid Delay------190 
180 


41 
TsIEI(RDA) 
IEI to RD I (Acknowledge) Setup Time 
120 
100 


42 
ThIEI(RDA) 
IEI to RD 1 (Acknowledge) Hold Time 
0 
0 


43 
TdIEI(IEO) 
IEI to IEO Delay Time 
120 
100 


44 
TdPC(IEO) 
PCLK 1 to IEO Delay 
250 
250 


45 -TdRDA(INT) --RD I to INT Inactive Delay -------------500 
500 ----4- 
46 
TdRD(WRQ) 
RD 1 to WR I Delay for No Reset 
47 
TdWRQ(RD) 
WR 1 to RD I Delay for No Reset 
48 
TwRES 
WR and RD Coincident Low for Reset 
49 
Trc 
Valid Access Recovery Time 


NOTES: 
3. Parameter applies only between transactions involving the 
ASCC. 
4. Open· drain output, measured with open·drain test load. 
S. Parameter is system dependent. For any ASCC in the daisy 
chain, TdIAi(RD) must be greater than the sum of TdPC(lEO) 


2023·007, 008, 009 


30 
15 


30 
30 
250 
250 
6TcPC 
6TcPC 
+200 
+ 130 
3 


for the highest priority device in the daisy chain, TsIEI(RDA) 
for the ASCC, and TdIElf(JEO) for each device separating them 
in the daisy chain. 
• Timings are preliminary and subject to change. 
r Units in nanoseconds (ns). 
. 
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General 
Timing 
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PCLK 


W/REQ 


REQUEST 


W/REQ 


WAT ________________________ ~------------------------------J 


RTllC,TRllC 


RECEIVE _________________ ~ 
I 


RllD 


TRllC,RTllC 


TRANSMIT 


TllD -c~; --------' 


--------'--~-----------®_I~---------~~:~ 


TRllC 
----------------------------------------------------- 


OUTPUT ____________________________ -J ~ ____ ~---------------------------------------------- 


\'"----~ 
\------'1 


TRllC--\ __ 
~~---.,\------'1 


CTS, DCD, Ai 
If\- 
I 
--'~~ 


2244-007 


No. 
Symbol 


2 
3 


TdPC(REQ) 
TdPC(W) 


TsRXC(PC) 


Parameter 


PCLK I to W IREQ Valid Delay 
PCLK I to Wait Inactive Delay 
RxC I to PCLK I Setup Time (PCLK 


4 
TsRXD(RXCr) 
RxD to RxC I Setup Time (Xl Mode) 


4 case only) 


4MHz 
Min 
Max 


250 
350 


80 
TwPCl 


0 


6MHz 
Min 
Max 
Notes*t 


250 
350 
70 
TwPCl 
1,4 


0 
1 
5-ThRXD(RXCr)-RxD to RxC I Hold Time (Xl Mode)------- 150 
150 
1- 


6 
TsRXD(RXCf) 
RxD to RxC I Setup Time (Xl Mode) 
0 
0 
1,5 
7 
ThRXD(RXCf) 
RxD to RxC I Hold Time (Xl Mode) 
150 
150 
1,5 


8 
TsTXC(PC) 
TxC I to PCLK I Setup Time 
0 
0 
2,4 


9 
TdTXCf(TXD) 
TxC I to TxD Delay (Xl Mode) 
300 
300 
2 
10-TdTXCr(TXD)-TxC I to TxD Delay (Xl Mode)-----------300 
300 
2,5- 


11 
TdTXD(TRX) 
TxD to TRxC Delay (Send Clock Echo) 


12 
TwRTXh 
RTxC High Width 


13 
TwRTX1 
RTxC Low Width 


14 
TcRTX 
RTxC Cycle Time 
15-TcRTXX 
Crystal Oscillator Period 


16 
TwTRXh 
TRxC High Width 


17 
TwTRX1 
TRxC Low Width 


18 
TcTRX 
TRxC Cycle Time 


19 
TwEXT 
DCD or CTS or·RI Pulse Width 


NOTES: 
I. RxC is RTxC or TRxC, whichever is supplying the receive 
clock. 
2. TxC is TRxC or RTxC, whichever is supplying the transmit 
clock. 
3. Both RTxC and ill have 30 pF capacitors to ground con· 


nected to them. 


180 
180 
6 


180 
180 
6 


400 
400 
6 


250-1000---250-1000 
3- 


180 
180 
6 


180 
180 
6 


400 
400 
6 


200 
200 


4. Parameter applies only if the data rate is one· fourth the PCLK 


rate. In all other cases, no phase relationship between RxC and 
PCLK or TxC and PCLK is required. 
5. Parameter applies only to FM encoding/decoding. 
6. Parameter applies only for transmitter and receiver; DPLL and 
baud rate generator timing requirements are identical to chip 
PCLK requirements . 


• Timings are preliminary and subject to change. 
t Units in nanoseconds (ns). 
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lSI 
at 
en 
W 
.... 
;oJ 
fIl 
n 
fI2 


System 
Timing 
RTxC, TRxC 


RECEIVE 


W/REQ 
REQUEST 


W/REQ 


WAIT 


RTxC, TRxC 


TRANSMIT 


W/REQ 
REQUEST 


W/REQ 


WAIT 


DTR/REQ 
REQUEST 


cfS, DCD,RI 


-----------------------4------------' 


-----------------------4------------1 


CD 
~ 


4 MHz 
No. 
Symbol 
Parameter 
Min 
Max 


TdRXC(REQ) 
RxC t to W IREQ Valid Delay 
8 
12 


2 
TdRXC(W) 
RxC t to Wait Inactive Delay 
8 
12 


3 
TdRXC(lNT) 
RxC t to INT Valid Delay 
10 
16 


4 -TdTXC(REQ)-TxC l to W/REQ Valid Delay --------5--8 


5 
TdTXC(Vv) 
TxC l to Wait Inactive Delay 


6 
Tc:iTXC(DRQ) 
TxC l to DTRlREQ Valid Delay 


7 
8 


NOTES: 


TdTXC(INT) 


TdEXT(INT) 


TxC l to INT Valid Delay 
DCD or CTS Transition to INT Valid Delay 


5 
8 


4 
7 
6 
10 
2 
6 


6 MHz 
Min 
Max 


8 
12 
8 
12 


10 
16 
5--8 


5 
8 


4 
7 


6 
10 
2 
6 


I. ~n·drain output, measured with open-drain test load. 
• Timings are preliminary and subject to change. 
2. RxC is RTxC or TRxC, whichever is supplying the receive 
clock. 
3. TxC is TRxC or RTxC. whichever is supplying the transmit 
clock. 
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t Units equal to TcPC. 


Notes*t 


2 
1,2 
1,2 
3- 
1,3 
3 
1,3 
1 


2244-008 


Ordering 
Product 
Package/ 
Product 
Package/ 
Information 
Number 
Temp 
Speed 
Description 
Number 
Temp 
Speed 
Description 


Z8531 
CE 
4.0 MHz 
ASCC (40-pin) 
Z8531A 
CE 
6.0 MHz 
ASCC (40-pin) 


Z8531 
CM 
4.0 MHz 
Same as above 
Z8531A 
CM 
6.0 MHz 
Same as above 


Z8531 
CMB 
4.0 MHz 
Same as above 
Z8531A 
CMB 
6.0 MHz 
Same as above 


28531 
CS 
4.0 MHz 
Same as above 
28531A 
CS 
6.0 MHz 
Same as above 


28531 
DE 
4.0 MHz 
Same as above 
28531A 
DE 
6.0 MHz 
Same as above 


28531 
DS 
4.0 MHz 
Same as above 
28531A 
DS 
6.0 MHz 
Same as above 


28531 
PE 
4.0 MHz 
Same as above 
28531A 
PE 
6.0 MHz 
Same as above 


28531 
PS 
4.0 MHz 
Same as above 
28531A 
PS 
6.0 MHz 
Same as above 


NOTES: C = Ceramic, D = Cerdip, P = Plastic; CM = -55°C to + 125°C, E = -40°C to +85°C, M = -55°C to 125°C, 


MB = -55°C to + 125°C with MIL-STD-8S3 Class B processing, S = O°C to +70°C. 


00-2244.02 . 
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Zilog 


Features 


General 
Description 


2021-035. 036 


B Two independent 8-bit, double-buffered, 
bidirectional I/O ports plus a 4-bit 
special-purpose I/O port. I/O ports 
feature programmable polarity, 
programmable direction (Bit mode), "pulse 
catchers," and programmable open- 
drain outputs. 


[i] Four handshake modes, including 3-Wire 
(like the IEEE-488). 


IJ REQUEST/WAIT signal for high-speed data 
transfer. 


The 28536 CIO Counter/Timer and 
Parallel I/O element is a general-purpose 
peripheral circuit, satisfying most counter/ 
timer and parallel I/O needs encountered in 
system designs. This versatile device contains 
three I/O ports and three counter/timers. Many 
programmable options tailor its configuration 
to specific applications. The use of the device 
is simplified by making all internal registers 


1 


- 
0 
7 
_os 
_05 


DATA 
- 
04 
BUS 
_ 
03 
_°2 
_ 
0, 
-00 


{ 


_ViR 


COtITROL, 
-+- Rii 
Z8536 


TIMING, 
- 
A, 
CIO 


AND RESET 
_ 
Ao 


_CE 


{ 


iNr 


_ 
INTACK 
INTERRUPT 
_ 
lEI 


lEO 


PA 


7 
-) 


PAs_ 
PAs _ 


PA 
_ 


4 
PORT A 
PA3 
- 
PA2 
PA, _ 


PAo - 


PC 
3 -} 
PC 
_ 


2 
PORT C 
Pc,_ 
PCo- 


PB 


7 
-) 


PBs _ 


PBs _ 


PB4 
- 
PORTB 
PB 
3 
_ 
PB2_ 
PB, _ 


PBo _ 


PCLK +5V GNO 


Figure 1. Pin Functions 


Z8536 CIO 
CounterlTimer and 
Parallel 1/0 Unit 


'Product 
Specification 


September 1983 


• Flexible pattern-recognition logic, program- 


mable as a 16-vector interrupt controller. 


• Three independent 16-bit counter/timers 
with up to four external access lines per 
counter/timer (count input, output, gate, 
and trigger), and three output duty cycles 
(pulsed, one-shot, and square-wave), 
programmable. as retriggerable or 
nonretriggerable. 


II Easy to use since all registers are 
read/write. 


(command, status, and data) readable and 
(except for status bits) writable. In addition, 
each register is given its own unique internal 
address, so that any register can be accessed 
in two operations. All data registers can be 
directly accessed in a single operation. The 
CIO is easily interfaced to all popular 
microprocessors. 
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Pin 
Ao-Al' Address Lines (input). These two lines 


De13cription 
are used to select the register involved in the 
CPU transaction: Port A's Data register, Port 
B's Data register, Port C's Data register, or a 
control register. 


CEo Chip Enable (input, active Low). A Low 
level on this input enables the CIa to be read 
from or written to. 
Do-l>? Data Bus (bidirectional 3-state). These 
eight data lines are used for transfers between 
the CPU and the CIa. 
lEI. Interrupt Enable In (input, active High). 
lEI is used with lEO to form an interrupt daisy 
chain when there is more than one interrupt- 
driven device. A High lEI indicates that no 
other higher priority device has an interrupt 
under service or is requesting an interrupt. 
lEO. Interrupt Enable Out (output, active 
High). lEO is High only if IEI is High and the 
CPU is' not servicing an interrupt from the 
requesting CIO or is not requesting an inter- 
rupt (Interrupt Acknowledge cycle only). lEO 
is connected to the next lower priority device's 
IEI input and thus inhibits interrupts from 
lower priority devices. 
INT. Interrupt Request (output, open-drain, 
active Low). This signal is pulled Low when 
the CIa requests an interrupt. 
INTACK. Interrupt Acknowledge (input, active 
Low). This input indicates to the CIO that an 
Interrupt Acknowledge cycle is in progress. 
INTACK must be synchronized to PCLK, and 


Architecture 
The CIa Counter/Timer and Parallel I/O 


element (Figure 3) consists of a CPU interface, 


it must be stable throughout the Interrupt 
Acknowledge cycle. 


PAo-PA7. Port A I/O lines (bidirectional, 
3-state, or open-drain). These eight I/O lines 
transfer information between the CIO's Port A 
and external devices. 
PBo-PB,. Port B I/O lines (bidirectional, 
3-state, or open-drain). These eight I/O lines 
transfer information between the CIO's Port B 
and external devices. May also be used to 
provide external access to Counter/Timers 
1 and 2. 
PCo-PCa. Port C I/O lines (bidirectional, 
3-state, or open-drain). These four I/O lines 
are used to provide handshake, WAIT, and 
REQUEST lines for Ports A and B or to provide 
external access to Counter/Timer 3 or access 
to the CIO's Port C. 
PCLK. Peripheral Clock (input, TTL- 
compatible). This is the clock used by the 
internal control logic and the counter/timers 
in timer mode. It does not have to be the 
CPU clock. 
RD*. Read (input, active Low). This signal 
indicates that a CPU is reading from the CIa. 
During an Interrupt Acknowledge cycle, this 
signal gates the interrupt vector onto the data 
bus if the CIO is the highest priority device 
requesting an interrupt. 
WR*. Write (input, active Low). This signal 
indicates a CPU write to the CIa. 
·When RD and WR are detected Low at the same time (normally 
an illegal condition), the CIa is reset. 


three I/O ports (two general-purpose 8-bit 
ports and one special-purpose 4-bit port), 
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Figure 4. Porta A and B Block Diagram 


three 16-bit counter/timers, an interrupt- 
control logic block, and the internal-control 
logic block. An extensive number of program- 
mable options allow the user to tailor the con- 
figuration to best suit the specific application. 
The two general-purpose a-bit I/O ports 
(Figure 4) are identical, except that Port B can 
be specified to provide external access to 
Counter/Timers 1 and 2. Either port can be 
programmed to be a handshake-driven, 
double-buffered port (input, output, or bidirec- 
tional) or a control-type port with the direction 
of each bit individually programmable. Each 
port includes pattern-recognition logic, allow- 
ing interrupt generation when a specific pat- 
tern is detected. The pattern-recognition logic 
can be programmed so the port function's like 
a priority-interrupt controller. Ports A and B 
can also be linked to form a 16-bit I/O port. 
To control these capabilities, both ports con- 
tain 12 registers. Three of these registers, the 
Input, Output, and Buffer registers, comprise 
the data path registers. Two registers, the 
Mode Specification and Handshake Specifica- 
tion registers, are used to define the mode of 
the port and to specify which handshake, if 
any, is to be used. The reference pattern for 
the pattern-recognition logic is defined via 


three registers: the Pattern Polarity, Pattern 
Transition, and Pattern Mask registers. The 
detailed characteristics of each bit path (for 
example, the direction of data flow or whether 
a path is inverting or noninverting) are pro- 
grammed using the Data Path Polarity, Data 
Direction, and Special I/O Control registers. 
The primary control and status bits are 
grouped in a single register, the Command 
and Status register, so that after the port is ini- 
tially configured, only this register must be ac- 
cessed frequently. To facilitate initialization,' 
the port logic is designed so that registers 
associated with an unrequired capability are 
ignored and do not have to be programmed. 
The function of the special-purpose 4-bit 
port, Port C (Figure 5), depends upon the 
roles of Ports A and B. Port C provides the 
required handshake lines. Any bits of Port C 
not used as handshake lines can be used as 
I/O lines or to provide external access for the 
third counter/timer. 


Since Port C's function is defined primarily 
by Ports A and B, only three registers (besides 
the Data Input and Output registers) are 
needed. These registers specify the details of 
each bit path: the Data Path Polarity, Data 
Direction, and Special 1/0 Control registers. 
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Figure 5. Port C Block Diagram 


The three counter/timers (Figure 6) are all 
identical. Each is comprised of a 16-bit down- 
counter, a 16-bit Time Constant register 
(which holds the value loaded into the down- 
counter), a 16-bit Current Count register (used 
to read the contents of the down-counter), and 
two 8-bit registers for control and status (the 
Mode Specification and the Command and 
Status registers). 
The capabilities of the counter/timer are 
numerous. Up to four port I/O lines can be 
dedicated as external access lines for each 
counter/timer: counter input, gate input, trig- 
ger input, and counter/timer output. Three dif- 
ferent counter/timer output duty cycles are 
available: pulse, one-shot, or square-wave. 


The operation of the counter/timer can be pro- 
grammed as either retriggerable or nonretrig- 
gerable. With these and other options, most 
counter/timer applications are covered. 
There are five registers (Master Interrupt 
Control register, three Interrupt Vector 
registers, and the Current Vector register) 
associated with the interrupt logic. In addition, 
the ports' Command and Status registers and 
the counter/timers' Command and Status 
registers include bits associated with the inter- 
rupt logic. Each of these registers contains 
three bits for interrupt control and status: 
Interrupt Pending (IP), Interrupt Under Ser- 
vice (IUS), and Interrupt Enable (IE). 
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Figure 6. Counter/Timer Block Diagram 


The following describes the functions 
of the ports, pattern-recognition logiC, 
counter/timers, and interrupt logiC. 
I/O Port Operations. Of the CIO's three I/O 
ports, two (Ports A and B) are general- 
purpose, and the third (Port C) is a special- 
purpose 4-bit port. Ports A and B can be con- 
figured as input, output, or bidirectional ports 
with handshake. (Four different handshakes 
are available.) They can also be linked to form 
a single 16-bit port. If they are not used as 
ports with handshake, they provide 16 input or 
output bits with the data direction program- 
mable on a bit-by-bit basis. Port B also pro- 
vides access for Counter/Timers 1 and 2. In all 
configurations, Ports A and B can be pro- 
grammed to recognize specific data patterns 
and to generate interrupts when the pattern is 
encountered. 
The four bits of Port C provide the hand- 
shake lines for Ports A and B when required. 
A REQUEST/WAIT line can also be provided 
so that CIO transfers can be synchronized with 
DMAs or CPUs. Any Port C bits not used for 
handshake or REQUESTIWAIT can be used as 
input or output bits (indiVidually data-direction 
programmable) or external access lines for 
Counter/Timer 3. Port C does not contain any 
pattern-recognition logic. It is, however, 
capable of bit-addressable writes. With this 
feature, any combination of bits can be set 
and/or cleared while the other bits remain 
undisturbed without first reading the register. 
Bit Port Operations. In bit port operations, the 


port's Data Direction register specifies the 
direction of data flow for each bit. A 1 
specifies an input bit, and a 0 specifies an out- 
put bit. If bits are used as I/O bits for a 
counter/timer, they should be set as input or 
output, as required. 
The Data Path Polarity register provides the 
capability of inverting the data path. A 1 
specifies inverting, and a 0 specifies non- 
inverting. All discussions of the port opera- 
tions assume that the path is noninverting. 
The value returned when reading an input 
bit reflects the state of the input just prior to 
the read. A l's catcher can be inserteid into the 
input data path by programming a 1 to the 
corresponding bit position of the port's Special 
I/O Control register. When a 1 is detected at 
the l's catcher input, its output is set to 1 until 
it is cleared. The l's catcher is cleared 
by writing a 0 to the bit. In all other cases, 
attempted writes to input bits are ignored. 
When Ports A and B include output bits, 
reading the Data register returns the value 
being output. Reads of.Port C return the state 
of the pin. Outputs can be specified as open- 
drain by writing a 1 to the corresponding bit of 
the port's Special I/O Control register. Port C 
has the additional feature of bit-addressable 
writes. When writing to Port C, the four most 
significant bits are used as a write protect 
mask for the least significant bits (0-4, 1-5, 
2-6, and 3-7). If the write protect bit is written 
with a I, the state of the corresponding output 
bit is not changed. 
. 
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Ports with Handshake Operation. Ports A and 
B can be specified as 8-bit input, output, or 
bidirectional ports with handshake. The CIO 
provides four different handshakes for its 
ports: Interlocked, Strobed, Pulsed, and 
3-Wire. When specified as a port with hand- 
shake, the transfer of data into and out of the 
port and interrupt generation is under control 
of the handshake logic. Port C provides the 
handshake lines as shown in Table 1. Any Port 
C lines not used for handshake can be used as 
simple 1/0 lines or as access lines for 
CounterlTimer 3. 
When Ports A and B are configured as ports 
with handshake, they are double-buffered. 
This allows for more relaxed interrupt service 
routine response time. A second byte can be 
input to or output from the port before the 
interrupt for the first byte is serviced. Nor- 
mally, the Interrupt Pending (IP) bit is set and 
an interrupt is generated when data is shifted 
into the Input register (input port) or out of the 
Output register (output port). For input and 
output ports, the IP is automatically cleared 
when the data is read or written. Inbidirec- 
tional ports, IP is cleared only by command. 
When the Interrupt on "Two Bytes (ITB) control 
bit is set to 1, interrupts are generated only 
when two bytes of data are available to be read 
or written. This allows a minimum of 16 bits of 
-information to be transferred on each inter- 
rupt. With ITB set, the IP is not automatically 
cleared until the second byte of data is read 
or written. 
When the Single Buffer (SB) bit is set to 1, 
the port acts as if it is only single-buffered. 
This is useful if the handshake line must be 
stopped on a byte-by-byte basis. 
Ports A and B can be linked to form a 16-bit 
port by programming a 1 in the Port Link Con- 
trol (PLC) bit. In this mode, only Port A's 
Handshake Specification and Command and 
Status registers are used. Port B must be 
specified as a bit port. When linked, only Port 
A has pattern-match capability. Port B's 


Port AlB Configuration 
PC3 


Ports A and B: 
Bit Ports 
Bit I/O 


Port A: 
Input or Output Port 
RFD or DAV 
(Interlocked, Strobed, or Pulsed 
Handshake)· 


Port B: 
Input or Output Port 
REQUESTIW AIT 
(Interlocked, Strobed, or Pulsed 
or Bit I/O 


Handshake)· 


Port A or B: 
Input Port (3-Wire 
RFD (Output) 
Handshake) 


Port A or B: 
Output Port (3-Wire 
DA V (Output) 
Handshake) 


Port A or B: 
Bidirectional Port 
RFD or DAV 
(Interlocked or Strobed Handshake) 


pattern-match capability must be disabled. 
Also, when the ports are linked, Port B'sData 
register must be read or written before 
Port A's. 
When a port is speCified as a port with hand- 


shake, the type of port it is (input, output, or 
bidirectional) determines the direction of data 
flow. The data direction for the bidirectional 
port is determined by a bit in Port C (Table 1). 
In all cases, the contents of the Data Direction 
register are ignored. The contents of the 
Special 1/0 Control register apply only to out- 
put bits (3-state or open-drain). Inputs may not 
have l's catchers; therefore, those bits in the 
Special 1/0 Control registe~ are ignored. Port 
C lines used for handshake should be pro- 
grammed as inputs. The handshake specifica- 
tion overrides Port C's Data Direction register 
for bits that must be outputs. The contents of 
Port C's Data Path Polarity register still apply. 
Interlocked Handshake. In the Interlocked 
Handshake mode, the action of the CIa must 
be acknowledged by the external device 
before the next action can take place. Figure 7 
shows timing for Interlocked Handshake. An 


o~tput port does not indicate that new data is 
available until the external device indicates it 
is ready for the data. Similarly, an input port 
does not indicate that it is ready for new data 
until the data source indicates that the 
previous byte of the data is no longer 
available, thereby acknowledging the input 
port's acceptance of the last byte. This allows 
the CIa to interface directly to the port of a 28 
microcomputer, a UPC, an FlO, an FIFO, or 
to another CIa port with no external logic. 
A 4-bit deskew timer can be inserted in the 
Data Available (DAV) output for output ports. 
As data is transferred to the Buffer register, 
the deskew timer is triggered. After the 
number of PCLK cycles specified by the 
deskew timer time constant plus one, DAV is 
allowed to go Low. The deskew timer therefore 
guarantees that the output data is valid for a 
specified minimum amount of time before DA V 
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ACKIN 
REQUEST/WAIT 
Bit I/O 


or Bit I/O 


Bit I/O 
RFD or DAV 
ACKIN 


DAV (Input) 
REQUESTIW AIT 
DAC (Output) 
or Bit I/O 
DAC (Input) 
REQUESTIWAIT 
RFD (Input) 
or Bit I/O 


ACKIN 
REQUESTIW AIT 
IN/OUT 


or Bit I/O 


·Both Ports A and B can be specified Input or output with Interlocked, Strobed. or Pulsed Handshake at the same time if neither uses 
REQUESTIW AlT. 
Table 1. Port C Bll Utilization 
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goes Low. Deskew timers are available for out- 
put ports independent of the type of handshake 
employed. 


Strobed Handshake. In the Strobed Hand- 
shake mode, data is \\strobed" into or out of 
the port by the external logic. The falling edge 
of the Acknowledge Input (ACKIN) strobes 
data into or out of the port. Figure 7 shows 
timing for the Strobed Handshake. In contrast 
to the Interlocked handshake, the signal 
indicating the port is ready for anoth~r data 
transfer operates independently of the ACKIN 
input. It is up to the external logic to ensure 
that data overflows or underflows do not occur. 


3-Wire Handshake. The 3-Wire Handshake is 
designed for the situation in which one output 
port is communicating with many input ports 
simultaneously. It is essentially the same as the 
Interlocked Handshake, except that two signals 
are used to indicate if an input port is ready 
for new data or if it has accepted the present 
da ta. In the 3-Wire Handshake (Figure 8), the 
rising edge of one status line indicates that the 
port is ready for data, and the rising edge of 
another status line indicates that the data has 
been accepted. With the 3-Wire Handshake 
the output lines of many input ports can be ' 
bussed together with open-drain drivers; the 
output port knows when all the ports have 
accepted the data and are ready. This is the 


INPUT HANDSHAKE 


DATA:::)( 
VALID 
X'-________ _ 


RFD 


DATA LATCHED 
}N BUFFER REGISTER 


same handshake as is used on the IEEE-488 
bus. Because this handshake requires three 
lines, only one port (either A or B) can be a 
3-Wire Handshake port at a time. The 3-Wire 
Handshake is not available in the bidirectional 
mode. Because the port's direction can be 
changed under software control, however, 
bidirectional IEEE-488-type transfers can be 
performed. 


Pulsed Handshake. The Pulsed Handshake 
(Figure 9) is designed to interface to 
mechanical-type devices that require data to 
be held for long periods of time and need 
relatively wide pulses to gate the data into or 
out of the device. The logic is the same as the 
Interlocked Handshake mode, except that an 
internal counter/timer is linked to the hand- 
shake logic. If the port is specified in the input 
mode, the timer is inserted in the ACKIN path. 
The external ACKIN input triggers the timer 
and its output is used as the Interlocked Hand- 
shake's normal acknowledge input. If the port 
is an output port, the timer is placed in the 
Data Available (DAV) output path. The timer is 
triggered when the normal Interlocked Hand- 
shake DA V output goes Low and the timer out- 
put is used as the actual DAV output. The 
counter/timer maintains all of its normal 
capabilities. This handshake is not available to 
bidirechon"al ports. 


OUTPUT HANDSHAKE 


DATA 


BUFFER REGISTER 
"EMPTIED" 


NEXT BYTE 


NEXT BYTE 
SHIFTED FROM 
OUTPUT REGISTER TO 
BUFFER REGISTER 


Flguro 7. Interlockod and Strobod Handshakos 


INPUT HANDSHAKE 


DATA:::)( 
VALID 
X'-________ _ 


DAV 
INPUT 


RPD 
OUTPUT 


DAC 
'------+---1 'DATA SHIFTED 
TO INPUT REGISTER 


OUTPUT ----l,---' 


OUTPUT HANDSHAKE 


DATA 
NEXT BYTE 


nPD 
INPUT ______ 
J 


DAC 
INPUT 


DAV 
OUTPUT 


BUFFER REGISTER 
"EMPTIED" 


NEXT BYTE 


SHIFTED FROM 


OUTPUT REGISTER TO 
BUFFER REGISTER 


Figure 8. 3-Wiro Handshako 


457 


Functional 
Description 
(Continued) 


458 


REQUEST/WAIT Line Operation. Port C can 
be programmed to provide a status signal out- 
put in addition to the normal handshake lines 
for either Port A or B when used as a port with 
handshake. The additional signal is either a 
REQUEST ~r WAIT signal. The REQUEST 
signal indicates'when a port is ready to per- 
form a data transfer via the CPU interface. It is 
intended for use with a DMA-type device. The 
WAIT signal provides synchronization for 
transfers with a CPU. Three bits in the Port 
Handshake Specification register provide con- 
trols for the REQUEST/WAIT logic. Because 
the extra Port C line is used, only one port can 
be specified as a port with a handshake and a 
REQUEST/WAIT line. The other port must be 
a bit port. 
Operation of the REQUEST line is modified 
by the state of the port's Interrupt on Two 
Bytes (ITB) control bit. When ITB is a, the 
REQUEST line goes active as soon as the CIO 
is ready for a data transfer. If ITB is I, 
REQUEST does not go active until two bytes 
can be transferred. REQUEST stays active as 
long as a byte is available to be read or 
written. 
The SPECIAL REQUEST function is reserved 
for use with bidirectional ports only. In this 
case, the REQUEST line indicates the status of 
the register not being used in the data path at 
that time. If the IN/OUT line is High, the 
REQUEST line is High when the Output 
register is empty. If IN/OUT is Low, the 
REQUEST line is High when the Input register 
is full. 
Pattern-Recognition Logic Operation. Both 
Ports A and B can be programmed to generate 
interrupts when a specific pattern is recog- 
nized at the port. The pattern-recognition logic 
is independent of the port application, thereby 
allowing the port to recognize patterns in all of 
its configurations. The pattern can be indepen- 
dently specified for each bit as I, a, rising 
edge, falling edge, or any transition. Indi- 
vidual bits may be masked off. A pattern- 
match is defined as the simultaneous satisfac- 
tion of all nonmasked bit specifications in the 
AND mode or the satisfaction of any non- 
masked bit specifications in either of the OR or 
OR-Priority Encoded Vector modes. 


INPUT PORT 


ACKIN' 


OUTPUT PORT 


Figure 9. Pulsed Handshake 


The pattern specified in the Pattern Defini- 
tion register assumes that the data path is pro- 
grammed to be noninverting. If an input bit in 
the data path is programmed to be inverting, 
the pattern detected is the opposite of the one 
specified. Output bits used in the pattern- 
match logic are internally sampled before the 
invert/noninvert logic. 


Bit Port Pattern-Recognition Operations. Dur- 
ing bit port operations, pattern-recognition 
may be performed on all bits, including those 
used as I/O for the counter/timers. The input 
to the pattern-recognition logiC follows the 
value at the pins (through the invert/noninvert 
logic) in all cases except for simple inputs with 
l's catchers. In this case, the output of the l's 
catcher is used. When operating in the AND 
or OR mode, it is the transition from a no- 
match to a match state that causes the inter- 
rupt. In the "OR" mode, if a second match 
occurs before the first match goes away, it 
does not cause an interrupt. Since a match' 
condition only lasts a short time when edges 
are specified, care must be taken to avoid 
losing a match condition. Bit ports specified in 
the OR-Priority Encoded Vector mode generate 
interrupts as long as any match state exists. A 
transition from a no-match to a match state is 
not required. 
The pattern-recognition logiC of bit ports 
operates in two basic modes: transparent and 
latched. When the Latch on Pattern Match 
(LPM) bit is set to a (Transparent mode), the 
interrupt indicates that a specified pattern has 
occurred, but a read of the Data register does 
not necessarily indicate the state of the port at 
the time the interrupt was generated. In the 
Latched mode (LPM = I), the state of all the 
port inputs at the time the interrupt was 
generated is latched in the input register and 
held until IP is cleared. In all cases, the PMF 
indicates the state of the port at the time it is 
read. 
If a match occurs while IP is already set, an 
error condition exists. If the Interrupt On Error 
bit (IOE) is a, the match is ignored. However, 
if IOE is 1 after tne first IP is cleared, it is 
automatically set to 1 along, with the Interrupt 
Error (ERR) flag. Matches occurring while ERR 
is set are ignored. ERR is cleared when the 
corresponding IP is cleared. 
When a pattern-match is present in the OR-' 
Priority Encoded Vector mode, IP is set to l. 
The IP cannot be cleared until a match is no 
longer present. If the 'interrupt vector is allow- 
ed to include status, the vector returned dur- 
ing Interrupt Acknowledge indicates the 
highest priority bit matching its specification at 
the time of the Acknowledge cycle. Bit 7is the 
highest priority and bit a is the lowest.' The bit 
initially causing the interrupt may not be the 
one indicated by the vector if a higher priority 
bit matches before the Acknowledge. Once the 
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Acknowledge cycle is initiated, the vector is 
frozen until the corresponding IP is cleared. 
Where inputs that cause interrupts might 
change before the interrupt is serviced, the l's 
catcher can be used to hold the value. 
Because a no-match to match transition is not 
required, the source of the interrupt must be 
cleared before IP is cleared or else a second 
interrupt is generated. No error detection is 
performed in this mode, and the Interrupt On 
Error bit should be set to O. 


Ports with Handshake Pattern-Recognition 
Operation. In this mode, the handshake logic 
normally controls the setting of IP and, 
therefore, the generation of interrupt requests. 
The pattern-match logic controls the Pattern- 
Match Flag (PMF). The data is compared with 
the match pattern when it is shifted from the 
Buffer register to the Input register (input port) 
or when it is shifted from the Output register to 
the Buffer register (output port). The pattern 
match logic can override the handshake logiC 
in certain situations. If the port is programmed 
to interrupt when two bytes of data are 
available to be read or written, but the first 
byte matches the specified pattern, the 
pattern-recognition logic sets IP and generates 
an interrupt. While PMF is set, IP cannot be 
cleared by reading or writing the data 
registers. IP must be cleared by command. 
The input register is not emptied while IP is 
set, nor is the output register filled until IP is 
cleared. 
If the Interrupt on Match Only (IMO) bit is 
set, IP is set only when the data matches the 
pattern. This is useful in DMA-type application 
when interrupts are required only after a block 
of data is transferred. 
Counter/Timer Operation. The three 
independent 16-bit counter/timers consist of a 
presettable 16-bit down counter, a 16-bit Time 
Constant register, a 16-bit Current Counter 
register, an 8-bit Mode SpeCification register, 
an 8-bit Command and Status register, and the 
associated control logic that links these registers. 


PCLK/2 OR 
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OATE 
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Function 
C/Tl 
C/T2 
C/T3 


Counter/Timer Output 
PB 4 
PB 0 
PCO 


Counter Input 
PB 5 
PB 1 
PC 1 


Trigger Input 
PB 6 
PB 2 
PC2 


Gate Input 
PB 7 
PB 3 
PC 3 


Tablo 2. Counter/Timor External Access 


The flexibility of the counter/timers is 
enhanced by the provision of up to four lines 
per counter/timer (counter input, gate input, 
trigger input, and counter/timer output) for 
direct external control and status. Counter/ 
Timer l's external I/O lines are prOVided by 
the four most significant bits of Port B. 
Counter/Timer 2' s are prOVided by the four 
least significant bits of Port B. Counter/Timer 
3' s external I/O lines are provided by the four 
bits of Port C. The utilization of these lines 
(Table 2) is programmable on a bit-by-bit basis 
via the Counter/Timer Mode Specification 
registers. 
When external counter/timer I/O lines are 
to be used, the associated port lines must be 
vacant and programmed in the proper data 
direction. Lines used for counter/timer I/O 
have the same characteristics as simple input 
lines. They can be specified as inverting or 
noninverting; they can be read and used with 
the pattern-recognition logic. They can also 
include the l's catcher input. 
Counter/Timers 1 and 2 can be linked inter- 
nally in three different ways. Counter/Timer 
l's output (inverted) can be used as Counter/ 
Timer 2's trigger, gate, or counter input. 
When linked, the counter/timers have the 
same capabilities as when used separately. The 
only restriction is that when Counter/Timer 1 
drives Counter/Timer 2's count input, 
Counter/Timer 2 must be programmed with 
its external count input disabled. 
There are three duty cycles available for the 
timer/counter output: pulse, one-shot, and 
square-wave. Figure 10 shows the cOl,Jnter/ 
timer waveforms. When the Pulse mode 


/1 
I TC I TC-l I TC-l I TC-2 I· · • I 1 I' 6t I 


PULSE OUTPUT 
II 
-------I.~ L- 


,c 
ONE SHOT 
OUTPUT ___ 
.... 


SQUARE WAVE 


OUTPUT 


FIRST HALF ------------......,'r;.'---....I 


SQUARE WAVE - 
- 
- 
- 
- ---------.."r;., ----, 


OUTPUT 
SECOND HALF 


Figura 10. Counter/Timer Waveforms 
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is specified, the output goes High for one 
clock cycle, beginning when the down-counter 
leaves the count of 1. In the One-Shot mode, 
the output goes High when the counter/timer is 
triggered and goes 'Low when the down- 
counter reaches O. When the square-wave out- 
put duty cycle is specified, the counter/timer 
goes through two full sequences for each 
cycle. The initial trigger causes the down- 
counter to be loaded and the normal count- 
down sequence to begin. If a 1 count is 
detected on the down-counter's clocking edge, 
the output goes High and the time constant 
value is reloaded. On the clocking edge, when 
both the down-counter and the output are l's, 
the output is pulled back Low. 
The Continuous/Single Cycle (C/SC) bit in 
the Mode Specification register controls opera- 
tion of the down-counter when it reaches ter- 
minal count. If C/SC is 0 when a terminal 
count is reached, the countdown sequence 
stops. If the CISC bit is 1 each time the count- 
down counter reaches I, the next cycle causes 
the time constant value to be reloaded. The 
time constant value may be changed by the 
CPU, and on reload, the new time constant 
value is loaded. 
Counter/timer operations require loading the 
time constant value in the Time Constant 
register and initiating the countdown sequence 
by loading the down-counter with the time 
constant value. The Time Constant register is 
accessed as two 8-bit registers. The registers 
are readable as well as writable, and the 
access order is irrelevant. A 0 in the Time 
Constant register specifies a time constant of 
65,536. The down-counter is loaded in one of 
three ways: by writing a' 1 to the Trigger Com- 
mand Bit (TCB) of the Command and Status 
register, on the rising edge of the external 
trigger input, or, for Counter/Timer 2 only, on 
the rising edge of Counter/Timer l's internal 
output if the counters are linked via the trigger 
input. The TCB is write-only, and read always 
returns O .. 


Once the down-counter is loaded, the count- 
down sequence continues toward terminal 
count as long as all the counter/timers' hard- 
ware and software gate inputs are High. If any 
of the gate inputs goes Low (0), the countdown 
halts. It resumes when all gate inputs are 1 
again. 
The reaction to triggers occurring during a 
countdown sequence is determined by the state 
of the Retrigger Enable Bit (REB) in the Mode 
Specification register. If REB is 0, retriggers 
are ignored and the countdown continues nor- 
mally. If REB is I, each trigger causes the 
down-counter to be reloaded and the count- 
down sequence starts over again. If the output 
is programmed in the Square-Wave mode, 
retrigger causes the sequence to start over 
from the initial load of the time constant. 


The rate at which the down-counter counts is 
determined by the mode of the counter/timer. 
In the Timer mode (the External Count Enable 
[ECE] bit is 0), the down-counter is clocked 
internally by a Signal that is half the frequency 
of the PCLK input to the chip. In the Counter 
mode (ECE is 1), the down-counter is decre- 
mented on the rising edge of the counter/ 
timer's counter input. 
Each time the counter reaches terminal 
count, its Interrupt Pending (IP) bit is set to I, 
and if interrupts are enabled (IE = 1), an inter~ 
rupt is generated. If a terminal count occurs 
while IP is already set, an internal error flag is 
set. As soon as IP is cleared, it is forced to 1 
along with the Interrupt Error (ERR) flag. 
Errors that occur after the internal flag is set 
are ignored. 
The state of the down-counter can be deter- 
mined in two ways: by reading the contents of 
the down-counter via the Current Count 
register or by testing the Count In Progress 
(CIP) status bit in the Gommand and Status 
register. The CIP status bit is set when the 
down-counter is loaded; it is reset when the 
down-counter reaches O. The Current Count 
register is a 16-bit register, accessible as two 
8-bit registers, which mirrors the contents of 
the down-counter. This register can be read 
anytime. However, reading the register is 
asynchronous to the counter's counting, and 
the value returned is valid only if the counter 
is stopped. The down-counter can be reliably 
read "on the fly" by the first writing of a 1 to 
the Read Counter Control (RCC) bit in the 
counter/timer's Command and Status register. 
This freezes the value in the Current Count 
register until a read of the least significant 
byte is performed. 


Interrupt Logic Operation. The CIa has five 
potential sources of interrupts: the three 
counter/timers and Ports A and B. The 
priorities of these sources are fixed in the 
following order: Counter/Timer 3, Port A, 
Counter/Timer 2, Port B, and Counter/Timer 
1. Since the counter/timers all have equal 
capabilities and Ports A and B have equal 
capabilities, there is no adverse impact from 
the relative priorities. 
The CIa interrupt priority, relative to other 
components within the system, is determined 
by an interrupt daisy chain. Two pins, Inter- 
rupt Enable In (IEI) and Interrupt Enable Out 
(lEO), provide the input and output necessary 
to implement the daisy chain. When lEI is 
pulled Low by a higher priority device, the 
CIa cannot request an interrupt of the CPU. 
The following discussion assumes that the IEI 
line is High. 
Each source of interrupt in the CIa contains 
three bits for the control and status of the 
interrupt logic: an Interrupt Pending (IP) 
status bi\, an Interrupt Under Service (IUS) 


Functional 
Description 
(Continued) 


status bit, and an Interrupt Enable (IE) control 
bit. IP is set when an event requiring CPU 
intervention occurs. The setting of IP results in 
forcing the Interrupt (INT) output Low, if the 
associated IE is 1. 
The IUS status bit is set as a result of the 
Interrupt Acknowledge cycle by the CPU and 
is set only if its IP is of highest priority at the 
time the Interrupt Acknowledge" commences. 
It can also be set directly by the CPU . Its 
primary function is to control the interrupt 
daisy chain. When set, it disables lower prior- 
ity sources in the daisy chain, so that lower 
priority interrupt sources do not request ser- 
vicing while higher priority devices are being 
serviced. 
The IE bit provides the CPU with a means of 
masking off individual sources of interrupts. 
When IE is set to 1, interrupt is generated nor- 
mally. When IE is set to 0, the IP bit is set 
when an event occurs that wouid normally 
require service; however, the INT output is not 
forced Low. 
The Master Interrupt Enable (MIE) bit allows 
all sources of interrupts within the CIO to be 
disabled without having to individually set 
each IE to O. If MIE is set to 0, all IPs are 
masked off and no interrupt can be requested 
or acknowledged. The Disable Lower Chain 
(DLC) bit is included to allow the CPU to 
modify the system daisy chain. When the DLC 
bit is set to 1, the CIO's IEO is forced Low, 
independent of the state of the CIO or its lEI 


Programming 
The data registers within the CIO are 
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directly accessed by address lines Ao and Al 
(Table 3). All other internal registers are 
accessed by the following two-step sequence, 
with the address lines specifying a control 
operation. First, write the address of the target 
register to an internal 6-bit Pointer Register; 
then read from or write to the target register. 
The Data registers can also be accessed by 
this method. 
An internal state machine determines if 
accesses with Ao and Al equalling 1 are to the 
Pointer Register or to an internal control 
register (Figure 11). Following any control 
read operation, the state machine is in State b 
(the next control access is to the Pointer 
Register). This can be used to force the state 
machine into a known state. Control reads in 
State 0 return the contents of the last register 


a 
a 
a 
a 


Register 


Port C's Data Register 


Port B's Data R~gister 


Port A's Data Register 


Control Registers 


Tablo 3. Registor Seloction 


input, and all lower priority devices' interrupts 
are disabled. 
As part of the Interrupt Acknowledge cycle, 
the CIO is capable of responding with an 8-bit 
interrupt vector that specifies the source of the 
interrupt. The CIO contains three vector 
registers: one for Port A, one for Port B, and 
one shared by the three counter/timers. The 
vector output is inhibited by setting the No 
Vector (NV) control bit to 1. The vector output 
can be modified to include status information 
to pinpoint more precisely the cause of inter- 
rupt. Whether the vector includes status or not 
is controlled by a Vector Includes Status (VIS) 
control bit. Each base vector has its own VIS 
bit and is controlled independently. When 
MIE = 1, reading the base vector register 
always includes status, independent of the 
state of the VIS bit. In this ,way, all the infor- 
mation obtained by the vector, including 
statu's, can be obtained with one additional 
instruction when VIS is set to O. When 
MIE = 0, reading the vector register returns 
the unmodified base vector so that it can be 
verified. Another register, the Current Vector 
register, allows use of the CIO in a polled en- 
vironment. When read, the data returned is 
the same as the interrupt vector that would be 
output in an acknowledge, based on the 
highest priority IP set. If no unmasked IPs are 
set, the value FFH is returned. The Current 
Vector register is read-only. 


pOinted to. Therefore, a register can be read 
continuously without writing to the Pointer. 
While the CIO is in State 1 (next control 
access is to the register pOinted to), many 
internal operations are suspended-no IPs are 
set and internal status is frozen. Therefore, to 
minimize interrupt latency and to allow con- 
tinuous status updates, the CIO should not be 
left in State 1. 
The CIO is reset by forcing RD and WR Low 
simultaneously (normally an illegal condition) 
or by writing a 1 to the Reset bit. Reset 
disables all functions except a read from or 
write to the Reset bit; writes to all other bits 
are ignored, and all reads return 01 H. In this 
state, all control bits are forced to 0 and may 
be programmed only after clearing the Reset 
bit (by writing a a to it). 


HARDWARE 
SOF~:ARE­ 
RESET 


WR TO REG.O 


(BITO = 1) 


NOTE: 
State changes occur only when AO = Al = 1. No other 
accesses have effect. 


Figuro 11. Stato Machino Oporation 
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Registers 
Master Interrupt Control Register 
Address: 000000 


(ReadIWrite) 


I 071 0.1 051 0.1 031 0,1 0, I 
Do I , 


MASTER INTERRUPT~ 
JJ 
~I 
L RESET 
ENABLE (MIE) . 
L 
RIGHT JUSTIFIED ADDRESSES 
DISABLE LOWER CHAIN (DLC) 
0 = SHIFT LEFT (Ao from AD,) 


NO VECTOR (Ny) 
• 
1 = RIGHT JUSTIFY (Ao !rpm ADo) 


COUNTERfTlMERS VECTOR 
PORT A VECTOR INCLUDES 
INCLUDES STATUS (CT VIS) 
STATUS (PA VIS) 


PORT B VECTOR INCLUDES 
STATUS (PB VIS) 


Master Configuration Control Register 
Address: 000001 


(ReadIWrite) 


PORTB~~ 
ENABLE (PBE) 


COUNTERfTlMER 1 
ENABLE (CT1E) 


COUNTERfTlMER 2 
ENABLE (CT2E) 


PORT C AND COUNTERI 


TIMER 3 ENABLE 
(PCE AND CT3E) 


I L 
'O"~'M'." '''' 
CONTROLS (LC) 
. 


LC1 
LCO 
. T T g~U1~:~~~~~~Ri,.'~~i~~TN~ENT 


1 
0 
CIT 1'8 OUTPUT TRIGGERS CIT 2 
1 
1 
CIT 1'8 00fPUf IS CIT 2'. 
COUNT INPUT 


PORT A ENABLE (PAE) 


'----- PORT LINK CONTROL (PLC) 


0= PORTS A AND B OPERATE INDEPENDENTLY 
1 = PORTS A AND B ARE LINKED 
Figure 12. Master Control Registers 


Port Mode Specification Registers 
Addresses: 100000 Port A 


Port Handshake Specification Registers 
Addresses: 100001 Port A 
10 1000 Port B 
(ReadlWrite) 


101001 Port B 
(ReadIWrite) 


I~I~I~I~I~I~I~I~I 


. PORTTYPE~ 
SELECTS (PTS) 


PTS1 PTSO. 
o 
OBIT PORT 
o 
1 
INPUT PORT 
1 
0 
OUTPUT PORT 
1 
1 
BIDIRECTIONAL 
PORT 


INTERRUPT ON TWO 
L 


LATCH ON PATIERN MATCH (LPM) 
(BIT MODE) 
DESKEW TIMER ENABLE (DTE) 
(HANDSHAKE MODES) , 


PATIERN MODE SPECIFICATION 
BITS (PMS) 


PMS1 PMSO 
-- --0- DISABLE PATIERN MATCH 
1 
"AND"MODE 


HANDSHAKE TY. PE SPECIFICATION -.J. I ---c '''''''''.''''''"''"0' 
BITS (HTS) 
BITS 


HTS1 HTSO 
~~~~~~~I~H~ ~~~. C°o"NSTANT. 
o 
0 
INTERLOCKED HANDSHAKE 
LSB IS FORCED 1. 
o 
1 
STROBED HANDSHAKE 
1 
0 
PULSED HANDSHAKE 
1 
1 
THREE·WIRE HANDSHAKE 


REQUESTIWAIT SPECIFICATION BITS 
(RWS) 
BYTES (ITB) 


SINGLE BUFFERED 
MODE (SB) 
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o 
"OR" MODE 
1 
"OR·PRIORITY ENCODED 


VECTOR" MODE 
RWS2 
RWS1 
RWSO FUNCTION 
o 
-- REQUESTIWAIT DISABLED 
'----- INTERRUPT ON MATCH ONLY (IMO) 
o 
OUTPUT WAIT 
o 
INPUT WAIT 


1 
SPECIAL REQUEST 


1 
OUTPUT REQUEST 


1 
INPUT REQUEST 


Port Command and Status Registers 
Addresses: 001000 Port A 


001001 Port B 
(Read/Partial Write) 


INTERRUPT UNDER 


SERVICE (IUS) 


INTERRUPT ENABLE (IE) 


INTERRUPT PENDING (IP) 


IUS, IE, AND IP ARE WRITIEN USING 


THE FOLLOWING CODE: 


NULL CODE 


CLEAR IP & IUS 


SET IUS 


CLEAR IUS 


SET IP 


CLEAR IP 


SET IE 


CLEAR IE 


o 0 
0 


o 0 
o 1 
o 1 


1 
0 


1 
0 1 


1 0 


1 1 


INTERRUPT ERROR (ERR) ------' 


(READ ONLy) 


~ 


I L INTERRUPT ON ERROR (IOE) 
L PATIERN MATCH FLAG (PMF) 
(READ ONLy) 


INPUT REGISTER FULL (IRF) 
(READ ONLy) 


OUTPUT REGISTER EMPTY (ORE) 
(READ ONLy) 


Figure 13. Port Specifications Registers 
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Data Path Polarity Registers 
Addresses: 100010 Port A 
10 10 10 Port B 


f 


Data Direction Registers 
Addresses: 100011 Port A 
101011 Port B 


000101 Port C (4 LSBs only) 
(Read/Write) 


000110 Port C (4 LSBs only) 
(Read/W rite) 


'----- DATA PATH POLARITY (DPP) 
o ~ NON·INVERTING 
'----- DATA DIRECTION (DD) 


0 .. OUTPUT BIT 


1 ~ INVERTING 
1 =INPUT BIT 


Special II 0 Control Registers 
Addresses: 100100 Port A 


101100 Port B 
000111 Port C (4 LSBs only) 
(Read/Write) 


'------ SPECIAL INPUT/OUTPUT (SIO) 
0= NORMAL INPUT OR OUTPUT 
1 = OUTPUT WITH OPEN DRAIN OR 
INPUT WITH 1'9 CATCHER 


Figure 14. Bit Path Deflnltlon Registers 


Port Data Registers 
Addresses: 001101 Port A * 


001110 Port B* 
(Read/Write) 


"These registers can be 
addressed directly. 


Figure IS •. Port Data Registers 


Pattern Polarity Registers (PP) 


Addresses: 100101 Port A 
101101 Port B 
(Read/Write) 


Pattern Transition Registers (PT) 


Addresses: 100110 Port A 
101110 Port B 
(Read/W rite) 


Pattern Mask Registers (PM) 


Addresses: 100111 Port A 
10 1111 Port B 
(Read/Write) 


Port C Data Register 
Address: 001111 * 
(Read/Write) 


4 MSBs 
O. WRITING OF CORRESPONDING LSD ENABLED 
1- WRITING OF CORRESPONDING LSD INHIBITED 


(READ RETURNS 1) 


PM PT PP PATTERN SPECIFICATION 
- 
- 
X 
BIT MASKED OFF 
X 
ANY TRANSITION 
o ZERO 
1 
ONE 
o ONE TO'ZERO TRANSITION (\) 
1 
ZERO·TO·ONE TRANSITION (f) 


Figure 16. Pattern Deflnltlon Registera 
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Counter/Timer Command and StClt1!S Registers 
Addresses: 001010 Counter/Timer 1 


001011 Counter/Timer 2 
001100 Counter/Timer 3 
(ReadIPartial Write) 


"""";. ""' .. "'''''"~ -1 I I 


INTERRUPT ENABLE (IE) 
I 
I 


INTERRUPT PENDING (IP) 
. I 
I 


IUS, IE, AND IP ARE WRITTEN USING 


THE FOLLOWING CODE: 


NULL CODE 
0 
0 
0 


CLEAR IP • IUS 
0 
0 


SET IUS 
0 
1 


CLEAR IUS 
0 
1 
1 


SET IP 
1 
0 
0 


CLEAR IP 
1 
0 
1 


SET IE 
1 0 


CLEAR IE 
1 
1 


INTERRUPT ERROR (ERR) -----' 


(READ ONLy) 


ug~ 


L COUNT IN PROGRESS (CIP) 


(READ ONLy) 


TRIGGER COMMAND BIT (TCB) 
(WRITE ONLY· READ RETURNS 0) 


GATE COMMAND BIT (OCB) 


READ COUNTER CONTROL (RCC) 
(READ/SET ONLY- 
CLEARED BY READING CCR LSB) 


Counter/Timer Mode Specification Registers 
Addresses: 011100 Counter/Timer 1 


011101 Counter/Timer 2 
011110 Counter/Timer 3 
(Read/Write) 


CONTINUOUS sm. JJ~ 
GLE CYCLE (C/SC) 


EXTERNAL OUTPUT 


ENABLE (EOE) 


EXTERNAL COUNT 


ENABLE (ECE) 


EXTERNAL TRIGGER 


ENABLE (ETE) 


I Lom'mo=~m 
SELECTS (DCS) 


DCS1DCSO 
() () 
PULSE OUTPUT 
o 
1 
ONE·SHOT OUTPUT 


1 
0 
SQUARE·WAVE OUTPUT 


1 
1 
DO NOT SPECIFY 


RETRI3GER ENABLE BIT (REB) 
'----- EXTERNAL GAT!: ENABLE (EGE) 


Counter/Timer Current Count Registers 
Addresses: 010000 Counter/Timer l's MSB 
010001 Counter/Timer l's LSB 
010010 Counter/Timer 2's MSB 
010011 Counter/Timer 2'8 LSB 
010100 Counter/Timer 3's MSB 
010101 Counter/Timer 3's LSB 


MOST -----' 
SIGNIFICANT 


BYTE 


(Read Only) 


'----- LEAST 
SIGNIFICANT 
BYTE 


Counter/Timer Time Constant Registers 
Addresses: 010110 Counter/Timer l's MSB 
010111 Counter/Timer l's LSB 
011000 Counter/Timer 2's MSB 
011001 Counter/Timer 2's LSB 
011010 Counter/Timer 3's MSB 
011011 Counter/Timer 3's LSB 


MOST -----' 
SIGNIFICANT 


BYTE 


(Read/Write) 


'----- LEAST 
SIGNIFICANT 
BYTE 


Figure 17. Counter/Timer Registers 
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Register 
Address 
Summary 
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Address 
000000 
000001 
000010 
000011 
000100 
000101 
000110 
000111 


Address 
001000 
001001 
001010 
001011 
001100 
001101 
001110 
001111 


Address 
010000 
010001 
010010 
010011 
010100 
010101 
010110 
010111 
011000 
011001 
011010 
011011 
011100 
011101 
011110 
011111 


Interrupt Vector Register 
Addresses: 000010 Port A 


000011 Port B 
000100 Counter/Timers 
(Read/Write) 


'----- INTERRUPT VECTOR 


PORT VECTOR STATUS 


PRIORITY ENCODED VECTOR MODE: 
03 
~ 01 
X 
X 
X 
NUMBER OF HIGHEST PRIORITY BIT 
WITH A MATCH 


ALL OTHER MODES: 


03 
02 
01 
ORE iRF PMF NORMAL 
o 
0 
0 
ERROR 


COUNTERITIMER STATUS 


02 
01 
o 0 
crr3 
o 
1 
crr 2 
1 
0 
crr 1 
1 
1 
ERROR 


Current Vector Register 
Address: 011111 


(Read only) 


L-___ INTERRUPT VECTOR BASED 
ON HIGHEST PRIORITY 
UNMASKED IP. 
IF NO INTERRUPT PENDiNG 
ALL l's OUTPUT. 


Figure 18. Interrupt Vector Registera 


Main Control Registers 
Register Name 
Master Interrupt Control 
Master Configuration Control 
Port A's Interrupt Vector 
Port B's Interrupt Vector 
CounterlTimer's Interrupt Vector 
Port C's Data Path Polarity 
Port C's Data Direction 
Port C's Special 1/0 Control 


Most Often Accessed Registers 
Register Name 
Port A's Command and Status 
Port B's Command and Status 
CounterlTimer l's Command and Status 
CounterlTimer 2's Command and Status 
CounterlTimer 3's Command and Status 
Port A's Data (can be accessed directly) 
Port B's Data (can be acces.sed directly) 
Port C's Data (can be accessed directly) 


Counter/Timer Related Registers 
Register Name 
CounterlTimer l's Current Count-MSBs 
CounterlTimer l's Current Count-LSBs 
CounterlTimer 2's Current Count-MSBs 
CounterlTimer 2's Current Count-LSBs 
CounterlTimer 3's Current Count-MSBs 
CounterlTimer 3's Current Count-LSBs 
CounterlTimer I's Time Constant-MSBs 
CounterlTimer l's Time Constant-LSBs 
Counter/Timer 2's Time Constant-MSBs 
CounterlTimer 2's Time Constant-LSBs 
CounterlTimer 3's Time Constant-MSBs 
CounterlTimer 3's Time Constant-LSBs 
CounterlTimer l's Mode Specification 
CounterlTimer 2's Mode Specification 
CounterlTimer 3's Mope Specification 
Current Vector 


Address 
100000 
100001 
100010 
100011 
100100 
100101 
100110 
100111 


Address 
101000 
101001 
101010 
101011 
lCI100 
101101 
101110 
101111 


Port A Specification Registers 
Register Name 
Port A's Mode Specification 
Port A's Handshake Specification 
Port A's Data Path Polarity 
Port A's Data Direction 
Port A's Special I/O Control 
Port A's Pattern Polarity 
Port A's Pattern Transition 
Port A's Pattern Mask 


Port B Specification Registers 
Register Name 
Port B's Mode Specification 
Port B's Handshake Specification 
Port B's Data Path Polarity 
Port B's Data Direction 
Port B's Special 1/0 Control 
Port B's Pattern Polarity 
Port B's Pattern transition 
Port B's Pattern Mask 
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Read Cycle. At the beginning of a read cycle, 
the CPU places an address on the address bus. 
Bits Ao and Al specify a CIO register; the 
remaining address bits and status information 
are combined and decoded to generate a Chip 
Enable (CE) signal that selects the CIO. When 
Read (RD) goes Low, data from the specified 
register is gated onto the data bus. 


Ao-Ai ==x 
ADDRESS VALID 
C 


CE 
~ 
/ 


iffi 
\ 
I 


Do·D7 
( READ DATA }-- 


Figure 19. Read Cycle Timing 


Interrupt Acknowl~e. The CIO pulls its 
Interrupt Request (INT) line Low, requesting 
interrupt service from the CPU, if an Interrupt 
Pending (IP) bit is set and interrupts are 
enabled. The CPU responds with an Interrupt 
Acknowledge cycle. When Interrupt Acknowl- 
edge (lNTACK) goes true and the IP is set, the 


Write Cycle. At the beginning of a write 
cycle, the- CPU places an address on the data 
bus. Bits Ao and Al specify a CIO register; the 
remaining address bits and status information 
are combined and decoded to generate a Chip 
Enable (CE) signal that selects the CIO. When 
WR goes Low, data placed on the bus by the 
CPU is strobed into the specified CIO register. 


Ao-Ai ==x 
ADDRESS VALID 
C 


Ci 
~ 
/ 


VIii 
\ 
I 


Do-D7 
( 
WRITE DATA 
-r-- 


Figure 20. Write Cycle Timing 


CIO forces Interrupt Enable Out (lEO) Low, 
disabling all lower priority devices in the inter- 
rupt daisy chain. If the CIO is the highest 
priority device requesting service (IEI is 
High), it places its interrupt vector on the data 
bus and sets the Interrupt Under Service (IUS) 
bit when Read (RD) goes Low. 


INT ------------~£F<-------JI 


INTACK ~F-' 
____________ ..11 


" 
J) 
lEI 


lEO 
'-nf-' ----- 
/~ 


Do-D7 -----------...,£',,'-------« 
VECTOR 
}-- 


Figure 21. Interrupt Acknowledge Timing 
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Absolute 
Maximum 
Ratings 


Standard 
Test 
Conditions 


DC 
Charac- 
teristics 


Capacitance 
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Voltages on all inputs and outputs 
with respectto GND .......... -0.3 V to + 7.0 V 
Operating Ambient 
Temperature ................. As Specified in 
Ordering Information 
Storage Temperature ........ -65°C to + 150°C 


The characteristics below apply for the 
folloWing standard test conditions, unless 
otherwise noted. All voltages are referenced to 
GND. Positive current flows into the refer- 
enced pin. Standard conditions are as follows: 


+5V 


2.2K 


Figure 22. Standard Test Load 


Symbol 
Parameter 
Min 


VIH 
Input High Voltage 
2.0 


VIL 
Input Low Voltage 
-0.3 


VOH 
Output High Voltage 
2.4 


VOL 
Output Low Voltage 


IlL 
Input Leakage 


IOL 
Output Leakage 


Icc 
Vee Supply Current 


Stresses greater than those listed under Absolute Maxi: 
mum Ratings may cause permanent damage to the device. 
This is a stress rating only; operation of the device at any 
condition above those indicated in the operational sections 
of these specifications is not implied. Exposure to absolute 
maximum rating conditions for extended periods may affect 
device reliability. 


111 +4.75 V ~ Vee ~ +5.25 V 


II GND = a V 


r! TA as specified in Ordering Information 
All ac parameters assume a load capacitance 
of 50 pF max. 


FROM OUTPUT 
UNDER TEST 


+5V d 


2•2K 


50 PFr 


Figure 23. Open-Drain Test Load 


Max 


Vee+ 0.3 


0.8 


0.4 
0.5 


±1O.0 


± 10.0 


200 


Unit 


V 


V 


V 


V 


V 


p.A 


p.A 
rnA 


Condition 


IoH = - 250 p.A 


IOL = +2.0 rnA 


IoL = +3.2 rnA 
0.4 :S VIN :S + 2.4 V 


0.4 :S VOUT :S +2.4 V 


Vee = 5 V ± 5% unless otherwise specified, over speCified temperature range. 


Symbol 
Parameter 
Min 
Max 
Unit 
Test Condition 


CIN 
Input Capacitance 
10 
pF 
Unmeasured Pins 
COUT 
Output Capacitance 
15 
pF 
Returned to Ground 


Cvo 
Bidirectional Capacitance 
20 
pF 


f = 1 MHz, over specified temperature range. 
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CPU 
Interface 
Timing 


Interrupt 
Timing 


Interrupt 
Acknow ledge 
Timing 
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PCLK 


AO-Ai 


Do-Dr 
WRITE ______ 
~ 
DATA VALID 


----~/~ 


CE 1--/------,@rr'L 
"MWR~' 
\\-. __ 
_ 


INPUTIS) 
_ 
PATTERN MATCH ~ 
__ p~A~n~E~R~N~M~~~C~H:ES~ __________ ~ 
___________ _ 


BIT PORT 
t.. ________ -,@I-____ --._I 


COUI4TER 
I"PUT _____ 
_ 


PCLK 


Do-Dr 


lEI 


lEO 


2021-006, 007, 008 


4 MHz 
6MHz 
No. 
Symbol 
Parameter 
Min 
Max 
Min 
Max 
Notes*t 


TcPC 
PCLK Cycle time 
250 
4000 
165 
4000 


2 
TwPCh 
PCLK Width (High) 
105 
2000 
70 
2000 


3 
TwPCI 
PCLK Width (Low) 
105 
2000 
70 
2000 


4 
TrPC 
PCLK Rise Time 
20 
10 


5 -TfPC 
PCLK Fall Time 
20 
15 


6 
TsIA(PC) 
INTACK to PCLK t Setup Time 
100 
100 


7 
ThIA(PC) 
IN TACK to PCLK t Hold Time 
0 
0 


8 
TsIA(RD) 
IN TACK to RD 1 Setup Time 
200 
200 


9 
ThIA(RD) 
INTACK to RD t Hold Time 
0 
0 


10 - 
TsIA(WR) -- INTACK to WR 1 Setup Time 
200 
200 


11 
ThIA(WR) 
INTACK to WR t Hold Time 
0 
0 


12 
TsA(RD) 
Address to RD 1 Setup Time 
80 
80 


13 
ThA(RD) 
Address to RD t Hold Time 
0 
0 
~ 


14 
TsA(WR) 
Address to WR 1 Setup Time 
80 
80 
CO 
(JI 


15 - 
ThA(WR) -- Address to WR t Hold Time 
0 
0 
W 
('i) 


16 
TsCEl(RD) 
CE Low to RD 1 Setup Time 
0 
0 
6 
till 
17 
TsCEh(RD) 
CE H~gh to RD 1 Setup Time 
100 
70 
0 


18 
ThCE(RD) 
CE to RD t Hold Time 
0 
0 


19 
TsCEl(WR) 
CE Low to WR 1 Setup Time 
0 
0 


20 - 
TsCEh(WR) -- CE High to WR 1 Setup Time 
100 
70 


21 
ThCE(WR) 
CE to WR t Hold Time 
0 
0 


22 
TwRDl 
RD Low Width 
390 
250 


23 
TdRD(DRA) 
RD 1 to Read Data Active Delay 
0 
0 


24 
TdRDf(DR) 
RD 1 to Read Data Valid Delay 
255 
180 


25- TdRDr(DR)-- RD t to Read Data Not Valid Delay 
0 
0 


26 
TdRD(DRz) 
RD t to Read Data Float Delay 
70 
45 
2 


27 
TwWRl 
WR Low Width 
390 
250 


28 
TsDW(WR) 
Write Data to WR 1 Setup Time 
0 
0 


29 
ThDW(WR) 
Write Data to WR t Hold Time 
0 
0 


30 
Trc 
Valid Access Recovery Time 
1000* 
650 
3 


31 
TdPM(INT) 
Pattern Match to INT Delay (Bit Port) 
2+800 
2 
6 


32 
TdACK(lNT) 
ACKIN to INT Delay (Port with Handshake) 
10+600 
10 
4,6 


33 
TdCI(lNT) 
Counter Input to INT Delay (Counter Mode) 
2+700 
2 
6 


34 
TdPC(lNT) 
PCLK to INT Delay (Timer Mode) 
3+700 
3 
6 


35 
TsIA(RDA) 
INTACK to RD 1 (Acknowledge) Setup Time 
350 
250 
5 


36 
TwRDA 
RD (Acknowledge) Width 
350 
250 


37 
TdRDA(DR) 
RD! (Acknowledge) to Read Data Valid Delay 
250 
180 


38 
TdIA(lEO) 
INTACK! to lEO ! Delay 
350 
250 
5 
39-TdIEI(IEO)--IEI to lEO Delay 
150 
100 
5- 


40 
TsIEI(RDA) 
lEI to RD! (Acknowledge) Setup Time 
100 
70 
5 


41 
ThIEI(RDA) 
lEI to RD t (Acknowledge) Hold Time 
100 
70 


42 
TdRDA(lNT) 
RD ! (Acknowledge) to INT t Delay 
600 
600 


NOTES: 
1. Parameter does not apply to Interrupt Acknowledge trans- 
to RD I must be greater than the sum of TdIA(1EO) for the 
actions. 
highest priority peripheral, TsIEI(RDA) for the lowest priority 
2. Float delay is measured to the time when the output has 
peripheral, and TdLEI(1EO) for each peripheral separating them 
changed 0.5 V with minimum ac load and maximum dc load. 
in the chain. 
3. Trc is the specified number or 3 TcPC, whichever is longer. 
6. Units are equal to TcPC plus ns. 
4. The delay is from DAV I for 3-Wire Input Handshake. The 
• Timings are preliminary and subject to change. All timing refer- 
delay is from DAC r for 3-Wire Output Handshake. 
ences assume 2.0 V for a logic "I" and 0.8 V for a logic "a". 


5. The parameters for the devices in any particular daisy chain 
t Units in nanoseconds (ns), except as noted . 
. must meet the following constraint: The delay from INTACK I 
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Strobed 
Handshake 


Interlocked 
Handshake 


3-Wire 
Handshake 
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INPUT 


OUTPUT 


INPUT 


OUTPUT 


INPUT 


OUTPUT 


DATA ==x 
DATA VALID 
'k''---____ _ 
~~ 
_~y~J- 


RFD 


DATA 


ACKIN 


DAY 


DATA 


DAY 
INPUT 


RFD 


OUTPUT 


DAC 


OUTPUT 


DATA 


DAC 
INPUT 


RFD 


INPUT 


DiY 
OUTPUT 


2014-022, 023, 024 


4MHz 
6MHz 
No. 
Symbol 
Parameter 
Min 
Max 
Min 
Max 
Notes*t 


TsDI(ACK) 
Data Input to ACKIN I Setup Time 
0 
0 


2 
ThDI(ACK) 
Data Input to ACKIN I Hold Time- 
Strobed Handshake 
3 
TdACKf(RFD) 
ACKIN I to RFD I Delay 
0 
0 


4 
TwACKl 
ACKIN Low Width-Strobed Handshake 
5 - 
TwACKh--- ACKIN High Width-Strobed Handshake 


6 
TdRFDr(ACK) 
RFD I to ACKIN I Delay 
0 
0 


7 
TsDO(DAV) 
Data Out to DA V I Setup Time 
25 
20 


8 
TdDAVf(ACK) 
DA V I to ACKIN I Delay 
0 
0 


9 
ThDO(ACK) 
Data Out to ACKIN I Hold Time 
2 
2 
2 
10 - 
TdACK(DAV) - 
ACKIN I to DAV I Delay 
2 
2 
2- 


11 
THDI(RFD) 
Data Input to RFD I Hold Time-Interlocked 
Handshake 


12 
TdR'FDf(ACK) 
RFD I to ACKIN I Delay Interlocked Handshake 
0 
0 


13 
TdACKr(RFD) 
ACKIN I (DA V I) to RFD I Delay-Interlocked and 
3-Wire Handwshake 
0 
0 


14 
TdDAVr(ACK) 
DAV I to ACKIN I (RFD I)-Interlocked and 3-Wire 
Handshake 
0 
0 


15 - 
TdACK(DAV)- ACKIN I (RFD I) to DAV I Delay-Interlocked and 
3-Wire Handshake 
0 
0 


16 
TdDAVIf(DAC) 
DAV I to DAC I Delay-Input 3-Wire Handshake 
0 
0 


17 
ThDI(DAC) 
Data Input to DAC I Hold Tizpe-3-Wire Handshake 
0 
0 


18 
TdDACOr(DAV) DAC I to DAV I Delay-Input 3-Wire Handshake 
0 
0 


19 
TdDAVIr(DAC) DAV I to DAC I Delay-Input 3-Wire Handshake 
0 
0 
20 - 
TdDAVOf(DAC) DAV I to DAC I Delay-Output 3-Wire Handshake -0 
0 


21 
ThDO(DAC) 
Data Output to DAC I Hold Time-3-Wire 
,Handshake 
2 
2 
2 
22 
TdDACIr(DAV) DAC I to DA V I Delay-Output 3-Wire Handshake 
2 
2 
2 
23 
TdDAVOr(DAC) DAV I to DAC I Delay-Output 3-Wire Handshake 
0 
0 


NOTES: 
1. This time can be extended through the use of deskew timers. 
2. Units equal to Tcpe. 


• Timings are preliminary and subject to change. All timing refer-' 
ences assume 2.0 V for a logic "1" and 0.8 V for a logic "0". 


t Units in nanoseconds (ns), except as noted. 
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II 
en 
W 
~ 
n 
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Counter/ 
Timer 
Timing 


No. 
Symbol 


1 
TeCI 


2 
TClh 


3 
TWCIl 


4 
TfCI 


Parameter 


PCLK 


PCLK'2 


(INTERNAL) _____ 
...1 


COUNTER 


INPUT 


TRIGG~R 
INPUT 


GATE 
INPUT 


COUNTER 


OUTPUT 


Counter Input Cycle Time 
Counter Input High Width 


Counter Input Low Width 


Counter Input Fall Time 


4MHz 
Min 
Max 


500 
230 


230 


20 


6MHz 
Min 
Max 


330 
150 


150 


15 


Notes*t 


5-TrCI ----- Counter Input Rise Time --------------- 20 ------------15----------- 


6 
TsTI(PC) 
Trigger Input to PCLK I Setup Time (Timer Mode) 


7 
TsTI(CI) 
Trigger Input to Counter Input I Setup Time 
(Counter Mode) 
8 
TwTI 
Trigger Input Pulse Width (High or Low) 
9 
TsGI(PC) 
Gate Input to PCLK I Setup Time (Timer Mode) 


10 - 
TsGI(CI) --- Gate Input to Counter Input I Setup Time ------------------------ 
(Counter Mode) 


11 
ThGI(PC) 
Gate Input to PCLK I Hold Time (Timer Mode) 


12 
ThGI(CI) 
Gate Input to Counter Input I Hold Time 
(Counter Mode) 


13 
TdPC(CO) 
PCLK to Counter Output Delay (Timer Mode) 


1<1. 
TdCI(CO) 
Counter Input to Counter Output Delay 
(Counter Mode) 


NOTES: 
1. These parameters must be met to guarantee trigger or gate 
are valid for the next counter/timer cycle. 
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• Timings are preliminary and subject to change. All timing refer- 


ences assume 2.0 V for a logic "I" and 0.8 V for a logic "0". 


i Units in nanoseconds (ns). 


2021-009 


REQUEST/ 
WAIT 
Timing 


No. 
Symbol 


TdRD(REQ) 
2 
TdRD(WAIT) 
3 
TdWR(REQ) 


Parameter 


RD j to REQ j Delay 


RD j to WAIT j Delay 


WR j to REQ j Delay 


4 
TdWR(WAIT) 
WR j to WAIT j Delay 


4MHz 
Min 
Max 


500 
500 
500 
500 
5-TdPC(REQ)--PCLK I to REQ I Delay------------ 300 
6 
TdPC(WAIT) 
PCLK j to WAIT I Delay 
300 


7 
TdACK(REQ) 
ACKIN j to REQ I Delay 
8+ 100 


8 
TdACK(WAIT) 
ACKIN I to WAIT I Delay' 
10 + 600 


NOTES: 


6 MHz 
Min 
Max 
Notes*t 


1,2 


1,2 


1. The delay is fronm DAV I for 3-Wire Input Handshake. The 
delay is from DAC t for 3-Wire Output Handshake. 


• Timings are preliminary and subject to change. All timing refer- 
ences assume 2.0 V for a logic "1" and 0.8 V for a logic "0". 


2. Units equal to TcPC + ns. 


Reset 
Timing 


t Units in nanoseconds (ns). except as noted. 


RESET 


INTERNAL ----------------------~j' 


4MHz 
No. 
Symbol 
Parameter 
Min 
Max 


1 
TdRD(WR) 
Delay from RD I to WR I for No Reset 
50 


2 
TdWR(RD) 
Delay from WR I to RD I for No Reset 
50 


3 
TwRES 
Minimum Width of RD and WR both Low for Reset 
250 


• Timings are preliminary and subject to change. All timing refer- 
ences assume 2.0 V for a logic "1" and 0.8 V for a logic "0". 


2021-010,011 


t Unites in nanoseconds (ns). 


6MHz 
Min 
Max 


50 
50 


250 


Notes*t 
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Miscellaneous 
Port 
Timing 


No. 
Symbol 


TrI 
2 
T£1 
3 
Tw1's 


4 
TwPM 


5 
TsPMD 


6 
ThPMD 


NOTES: 


ANY INPUT 


1'. CATCHER 


INPUT -----+r 
~1'--: - - - 
~ 
------~I 
\~ __________ _ 


~;.;;. ------~~, f2521< 1. ..... ------ 


PATTERN MATCH ------..I~ 
~ 


4MHz 
SMHz 


Parameter 
Min 
Max 
Min 
Max 


Any Input Rise Time 
Any Input Fall Time 
l's Catcher High Width 
250 
Pattern Match Input Valid (Bit Port) 
750 


Data Latched on Pattern Match Setup Time (Bit Port) 
0 


Data Latched on Pattern Match Hold Time (Bit Port) 
1000 


100 
100 
170 


500 


o 


650 


100 
100 


Notes*t 


1. If the input is programmed inverting, a Low-going pulse of the 
• Timings are preliminary and subject to change. All timing 
same width will b~ detected. 
references assume 2.0 V for a logic "I" and 0.8 V for a logig "0" 


Ordering 
Information 
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t Units in nanoseconds (ns). 


Product 
Package/ 
Product 
Package/ 
Number 
Temp 
Speed 
Description 
Number 
Temp 
Speed 
Description 


28536 
CE 
4.0 MHz 
CIO (40-pin) 
Z8536A 
CE 
6.0 MHz 
CIO (40-pin) 


28536 
CM 
4.0 MHz 
Same as above 
Z8536A 
CM 
6.0 MHz 
Same as above 


28536 
CMB 
4.0 MHz 
Same as above 
Z8536A 
CMB 
6.0 MHz 
Same as above 


28536 
CS 
4.0 MHz 
Same as above 
Z8536A 
CS 
6.0 MHz 
Same as above 


Z8536 
DE 
4.0 MHz 
Same as above 
Z8536A 
DE 
6.0 MHz 
Same 3.S above 


28536 
DS 
4.0 MHz 
Same as above 
28536A 
DS 
6.0 MHz 
Same as above 


28536 
PE 
4.0 MHz 
Same as above 
Z8536A 
PE 
6.0 MHz 
Same as above 


28536 
PS 
4.0 MHz 
Same as above 
Z8536A 
PS 
6.0 MHz 
Same as above 


NOTES: C = Ceramic, D = Cerdip, P = Plastic; E = -40°C to +85°C, M = -55°C to 125°C, MB = -55°C to 125°C with MIL-STD-883 
with Class B processing, S = O°C to + 70°C. 


2014-028 OO·2021'()3 


Zilog 


FEATURES 


• Two independent 20 MHz oscillators generate two 10 


MHz clock outputs and one 20 MHz clock output. 


• Oscillator input frequency sources can be either 


crystals or external oscillators. 


• Outputs directly drive the Z80 and Z8000 micro- 
processor clock inputs. 


II Can be used as a general-purpose clock generator. 


!J 18-pin slimline package used; single + 5 V dc power 
required. 


GENERAL DESCRIPTION 


The Z8581 Clock Generator and Controller is a versatile 
addition to Zilog's family of Universal microprocessor 
components. The selective clock-stretching capabilities 
and variety of timing outputs produced by this device 
allow it to easily meet the timing design requirements of 
systems with microprocessors and LSI peripherals. The 


!8$$ n (cRotCn" (GentleraRo~ 
annuail <Ccrnlftrtcllllert 


lIDrto«ll un <eft 


§pecii~iicaftii«DIm. 


September 1983 


13 Provides ability to stretch High and/or Low phase of 


clock signal under external control. 


DOn-chip 2-bit counter can be used to selectively 


stretch clock cycles. 


[J On-chip reset logic 


o Reset output is synchronized with System Clock 


output. 
o Power-up reset period is maintained for a minimum 
of 30 ms. 
o External input initiates system reset. 


clock output drivers of the Z8581 also meet the non-TTL 
voltage requirements for driving NMOS clock inputs with 
no additional external components. The Z8581 provides 
an elegant, single-chip solution to the design of system 
clocks for microprocessor-based products. 


ZCLK{ _ 
~~~: 
STRETCH 
_ 
CONTROL 
- 
STRH 
-INH 


XTL1A 


XTL1B 
} REF.FREQ. SOURCE 
FOR SYS_ CLOCK OSC 


OSC 


RESET 
RSTI 
ZCLK 


{ 


Z8581 


CONTROL 
RSTO 


START COUNT _ 
STRT 


NO. OF RISING { 
CO 
EDGES COUNTED 
C1 


XTL2A 


XTL2B 


TCLK 
t 


+5V 
GND 


Figure 1. Pin Functions 


2248-001. 002 


TIME BASE 


SYSTEM CLOCK 


} REF. FREQ. SOURCE 
FOR GEN. PURPOSE OSC 


GENERAL PURPOSE CLOCK 


XTL1A 
RSTI 


XTL1B 
RSTO 


STRH 
OSC 


INH 
ZCLK 


+5V 
GND 


ADD1 
TCLK 


ADD2 
XTL2A 


STRT 
XTL2B 


CO 
C1 


Figure 2. Pin Assignments 
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The Z8581 is packaged in an 18-pin slimline DIP (see 
Figure 1 for pin functions and Figure 2 for pin 
assignments). 


The Z8581 oscillators are referenced as the system 
clock oscillator and the general-purpose clock oscillator. 
Both oscillators are driven by external crystals or other 
frequency sources. 


System Clock Oscillator. The timing outputs provided 
by this oscillator consist of a Time Base output (OSC), at 
the frequency of the reference source, and a stretchable 
System Clock output (ZClK), at a frequency determined 
by the stretch control inputs. An on-chip TTL driver at 
OSC and an NMOS driver at ZClK eliminate the need for 
external buffers or drivers. The NMOS drivers can drive 
200 pF loads to within 0.2 volts of Vee and sink 
8 mA. Output rise and fall times are 10 ns maximum. 


ZClK can be stretched under program or hardwired con- 
trol by selectively adding periods equivalent to a full OSC 
cycle to either the High or low portion of a clock cycle. 
One, two, or three periods can be added to double, triple, 
or quadruple the duration of the selected ZClK half- 
cycle. Adding periods to ZClK is a function of the ADD1 
and ADD2 inputs. These active low inputs are sampled 
prior to the rising edge of signal OSC; their sampled 
status represents the number of periods to be added to 
ZClK. 


Two adClitional control inputs, INH and STRH, affect the 
stretch function. Input INH, when asserted, inhibits the 
function of ADD1 and ADD2. Input STRH stretches the 
ZClK output for as long as it is asserted (low); it over- 
rides all other stretch control inputs. 


Table 1 summarizes the functions performed by the 
stretch control inputs. 


The system clock oscillator also contains a 2-bit \ ZClK 
counter. This counter, when initialized by the assertion 
of STRT, counts the next four rising edges of the ZClK 
output. The current count is presented on outputs CO and 
C1. This counter and its outputs enable the user to deter- 
mine the occurrence (rising edge) of each of four clocks 
after a specific event (STRT is asserted). This facility 
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Table 1. Stretch Control Functions 


o 
x 
o 


ADD2 
ADD1 


x 
x 
x 
x 
o 
0 


o 
1 
o 


Notes: X = Don't Care, 1 = High, 0 = Low 


Periods Added 


Unlimited _ 


o 
3 
2 
1 
o 


can, for example, be used to determine when a delay is 
to be inserted into a CPU machine cycle when STRT is 
triggered by either an tv; 1 (Z80) or an AS (Z8000) input 
Signal. 


The clock stretch capability allows systems to run at the 
nominal high speed of ZClK, except during cycles that 
require more time than usual to complete a transaction. 
For example, extended access time may be required in 
accessing certain areas of memory, in accessing I/O 
devices, or in other CPU/Peripheral transactions. 
F-igures 3 and 4 illustrate, respectively, the circuit con- 
figuration and timing required to stretch the Z8000 Ad- 
dress Strobe (AS) and Data Strobe (DS) to allow more 
time for address functions and to enable the CPU to 
operate with memories that have a relatively long ac- 
cess time. 


In addition, the ZClK stretch control logic can be hard- 
wired to meet various duty cycle requirements. For 
example, a simple hardwired connection can cause 
every other ZClK cycle to be stretched to produce a 
ZClK output with a 33 % duty cycle. 


-The system clock oscillator also provides a system reset 
output (RSTO) that is synchronized with ZClK. This out- 
put is controlled by a system reset input (RSTI) during 
normal system reset operations and by delay circuitry in 
the system clock oscillator during power-up operations. 
During a normal system reset operation, a low on RSTI 
causes RSTO to be asserted (low) on the next rising 
edge of ZClK. Output RSTO is held low for a period of 
16 ZClK clock cycles (the required reset time for both 
the Z80 and Z8000 CPU system reset functions). During 
a power-up operation, RSTO is asserted for a minimum 
of 30 ms after power is turned on (the time required for 
both the Z80 and Z8000 power-up functions). 


General·Purpose. Oscillator. This oscillator provides a 
fixed frequency General-Purpose Clock output (TClK) at 
half its source frequency. This output is useful for 
system timing functions such as controlling a baud rate 
generator. Output TClK can also be used as the fre- 
quency reference source for the system clock oscillator. 


+5V~ 
STRH 
osc 
osc 


ZCLK 
+5V~ 
INH 
ZCLK 


Z8581 
AS--c 
STRT 


ADD1 
C1 


ADD2 


Figure 3. Configuration for Stretching Z8000 


Address (AS) and Data (OS) Strobes 


2248-003 


OSC 


~1·~----T1----~~~II~·~------T2--------~~I~T3~ 


ZCLK 
I 
~r- 


co 


C1 


.... ___ ...... I~ 
ONE OSC CLOCK PERIOD ADDED 


I 


TWO OSC CLOCK PERIODS ADDED --.1 
r 
.... ______ 
____. 


Figure 4. Timing Diagram Stretching Z8000 AS and DS 


PIN DESCRIPTIONS 


Figures 1 and 2, respectively, show the pin functions and 
assignments of the Z8581. 


ADD1, ADD2. Add Delay 1 (input, active Low) and Add 
Delay 2 (input, active Low). These Signals control the 
addition of one, two, or three delay periods to a selected 
half-cycle of the ZCLK output. 


CO, C1. ZCLK Count a (output, active High) and ZCLK 
Count 1 (ou~put, active High). These signals indicate, in 
binary, the number or rising edges of ZCLK that have oc- 
curred after the assertion of the STRT input. 


INH. Inhibit Delay (input, active Low). When asserted, 
this signal inhibits the functions of inputs ADD1 and 
ADD2. 


OSC. Time Base Clock (output, active High). This signal 
provides a TIL-compatible clock output at the same fre- 
quency as the system clock frequency source. 


RSTI. Reset In (input, active Low). When asserted, this 
Signal indicates a reset condition and initiates the asser- 
tion of RSTO synchronized with ZCLK. 


RSTO. Reset Out (output, active Low). When asserted, 
this signal indicates that a system reset condition is re- 
quired, either by RSTI going Low or by a system power- 
up condition. 


STRT. Start Count (input, active Low). When asserted, 
this signal resets a two-bit binary counter and then 
enables the counter to count the "rising edges of the 
ZCLK output. 
. 


2248-004 


STRH. Delay ZCLK (input, active Low). When asserted, 
this Signal causes the current half-cycle of the ZCLK out- 
put to be delayed (stretched) for as long as STRH is held 
Low. This control input overrides the ADD1, ADD2, and 
INH functions. 


TClK. General-Purpose Clock (output, MOS-compat- 
ible, active High). This Signal is the timing output of the 
general-purpose oscillator. TCLK's frequency is half that 
of the external oscillator used to drive the general- 
purpose oscillator. 


XTAl1A, XTAl1 B. System Clock Frequency Source A 
(input, active High) and System Clock Frequency Source 
B (output, active High). These signals are used by the ex- 
ternal oscillator to drive the internal system clock 
oscillator and the OSC output. 


XTAl2A, XTAl2B. General-Purpose Clock Frequency 
Source A (input, active High) and General-Purpose Clock 
Frequency Source B (output, active High). These signals 
are used by the external oscillator to drive the internal 
general-purpose clock oscillator. 


ZelKo System Clock (output, MOS-compatible, active 
High). This signal is the timing output of the system clock 
oscillator. This clock can be modified by the delay 
(stretch) control inputs. Its frequency, when unmodified, 
is half that of the external system clock frequency 
source. 
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Vee 


RSTI----------------~ 
__ ~ 
1------ RSTO 


OSC 


~~+---------~Co 


COUNT 


R 01 ~--...---------~ C1 


STRT----------~--~--~~--~ 


STRH ----------~I 
INH---------.... I 


ADD1---------.... 
ADD2-------1 


STRETCH ~ 
0001 
CONTROL 
lOGIC 
1-0.. __ 
.... 


XTAl1B~-------_ 
• ...,r:;lI-------I.~r:lI---~~ TClK 


XTAL2B-0I/J 
L.::J 
L...:J 
~ 


Figure 5. Z8581 Functional Block Diagram 


SYSTEM INTERFACE CONSIDERATIONS 


Due to the fast rise and fall times produced by the 
Z8581 , transmission line concepts must be applied in 
order to avoid ringing and reflections on the clock out· 


quires a high frequency 0.01 /tF ceramic capacitor be· 
tween Vcc and ground, and the leads connecting this 
capacitor to the pins should be kept as short as possible. 
'putS. More specifically, the interconnections between 
the clock outputs and the loads they are driving must be 
treated as transmission lines, and it is necessary to 
match the source impedance of the clock outputs to the 
characteristic impedances of these transmission lines. 
In most cases the impedances can be matched by plac· 
ing termination resistors in series with the clock outputs. 
These resistors range in value from 22 to 220 ohms, with 
the value chosen to optimize the clock risetime at the 
load. (See example below.) It is important to control the 
impedance seen by the clock output by keeping leads 
short and avoiding stray inductances wherever possible. 


Another important consideration is the bypass capacitor. 
To avoid distortion of the power supply, the Z8581 reo 
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220 
ZClK 
ClK 


Z8581 
Z8000 


GND 
VCC 


Figure 6. Z8581/Z8000 Interface 
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AC CHARACTERISTICSt 


6 MHz 
10 MHz 
No. Symbol 
Parametor 
Min. 
Max. 
Min 
Max 
Units 


1 TwCH 
Clock Input High Width* 
31 
18 
ns 


2 TwCL 
Clock Input Low Width* 
31 
18 
ns 


3 TpC 
Clock Inpyt Cycle Time* 
82 
50 
ns 


4 TfC 
Clock Input Fall Time* 
10 
7 
ns 


5 TrC 
Clock Input Rise Time* 
10 
7--ns 


6 TdOSC 
Clock Input to OSC Delay 
30 
20 
ns 


7 TdZC 
OSC to ZCLK Delay 
10 
10 
ns 


8 TfZC 
ZCLK Fall Time 
10 
10 
ns 


9 TrZC 
ZCLK Rise Time 
10 
10 
ns 


10 TsSC 
Stretch Controls to OSC t Setup 
35 
·20 
ns 


11 
ThSC 
Stretch Controls to OSC t Hold 
20 
10 
ns 
N 


12 Td(ST/CR) 
STRT l to 2·bit Counter Reset Delay 
35 
25 
ns 
00 
m 


13 Td(ZC/CC) 
ZCLK t to 2·bit Counter Change Delay 
-5 
10 
-5 
10 
ns 
eo 
.... 


14 Tw(STRD 
STRT Low Width 
50 
30 
ns 
" 
15 Td(RSTO) -- ZCLK t to RSTO l Delay 
30 
20--ns 
R 


16 Ts(RSTI) 
RSTJ l to ZCLK t Setup 
30 
20 
ns 


17 Th(RSTI) 
RSTI l to ZCLK t Hold 
30 
20 
ns 


18 Tw(RSTO) 
RSTO Low Width 
16 
16 
cycles 


19 Ts(ST/ZC) 
STRT l to ZCLKt Setup to include ZCLK edge 
40 
30 
ns 


20 TdTC 
Clock Input to TCLK Delay 
40 
30--ns 


21 
TrTC 
TCLK Rise Time 
10 
10 
ns 


22 TfTC 
TCLK Fall Time 
10 
10 
ns 


·Clock input other than a crystal oscillator 
tAli timings are preliminary and subject to change. 
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XTAL1A 


OSC 


ZCLK 


STRETCH 
CONTROL 


CO,C1 


XTAL2A 


TCLK 


®ll'-'~~~~====-@:~~~--------:1 


Timing measurements are made at the follow- 
ing voltages: 


ZCLK, TCLK 


Output 


Input 
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High 
Low 


4.0V 
2.0V 
2.0V 


0.8 V 


0.8 V 


0.8 V 


2248·006 


ABSOLUTE MAXIMUM RATINGS 


Voltages on all inputs and outputs 
with respect to GND ............... -0.3 V to + 7.0 V 


Operating Ambient 
Temperature ............... See ordering information 


Storage Temperature ............. -65 °e to + 150 °e 


STANDARD rEST CONDITIONS 


The characteristics below apply for the following stan- 
dard test conditions, unless otherwise noted. All voltages 
are referenced to GND (0 V). Positive current flows into 
the referenced pin. Available operating temperature 
ranges are: 


Iii S* = ooe to + 70oe, 


+4.75 V ~ VCC ~ +5.25 V 


II E* = -40 oe to +85°e, 


+4.5 V ~ VCC ~ +5.25 V 


m M* = - 55°e to + 125°e, 


+4.5 V ~ Vcc ~ +5.5 V 


·See Ordering Information section for package temperature range and product 
number. 
All ac parameters assume a total load capacitance (in- 
cluding parasitic capacitances) of 100 pF max, except 


DC CHARACTERISTICS 


Symbol 
Paramoter 
Min 


Stresses greater than those listed under Absolute Maximum Ratings 
may cause permanent damage to the device. This is a stress rating 
only: operation of the device at any condition above those indicated in 
the operational sections of these specifications is not implied. Ex- 
posure to absolute maximum rating conditions for extended periods 
may affect device reliability. 


for parameters 8, 9, 21, and 22 (200 pF max). Timing 
references between two output signals assume a load 
difference of 50 pF max. 


+5V 


2.1K 


FROM OUTPUT {)----+--+--I< 


UNDER TEST 


Max 
Unit 
Condition 


VCH 
Clock Input High Voltage 
Vcc-O.4 
Vcc+ 0.3 
V 
Driven by External Clock Generator 


VCl 
Clock Input low Voltage 
-0.3 
0.45 
V 
Driven by External Clock Generator 


VIH 
Input High Voltage 
2.0 
Vcc+ 0.3 
V 


VIH RESET 
Input High Voltage on 
2.4 
Vcc +0.3 
V 
RESET pin 


Vil 
Input low Voltage 
-0.3 
0.8 
V 


VOH 
Output High Voltage 
2.4 
V 
IOH = -250 pA 


VOH 
Output High Voltage 
Vcc- 0.2 
V 
IOH = -250 pA 


(ZClK, 
TClK) 


VOL 
Output low Voltage 
0.4 
'V 
10l = +2.0 mA 


III 
Input leakage 
±10 
pA 
0.4 :S VIN :S + 2.4 V 


Icc 
Vcc Supply Current 
150 
mA 
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ORDERING INFORMATION 


Product 
Packagel 
Product 
Packagel 
Number 
Temp 
Speed 
Description 
Number 
Temp 
Speed 
Description 


Z8581 
CIS 
6 MHz 
CGC (18-pin) 
Z8581 
CIS 
10 MHz 
CGC (18-pin) 


Z8581 
DIS 
6 MHz 
Same as above 
Z8581 
DIS 
10 MHz 
Same as above 


Z8581 
PIS 
6 MHz 
Same as above 
Z8581 
PIS 
10 MHz 
Same as above 


C = Ceramic, D = Cerdip, P = Plastic, S = Standard 0°-70°C 
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00-2315'()2 


Z8 


Family 


Zilog 


Pioneering the . 
Micro world 


In 1976, Zilog emerged into the 
microprocessor world with its Z80 
CPU Family. With this classic of 
8-bit architecture that has become 
industry-standard, Zilog established 
its design expertise and cost- 
efficient production capability. 
While the Z80 earned and main- 


tained strong customer support, in- 
evitable demands for new applica- 
tions-intelligent terminals, 
dedicated control and communica- 
tion-spawned an accompanying 
need for a new, lean technology. 
With an instinct for simplicity and 
elegance, Zilog architects created 
a microcomQuter with the most 
sophisticated computing power 
available on a single chip: the Z8 
Family. In a bold departure from 
the standard AlB accumulator 
tradition, a fresh, register-oriented 
architecture was devised that 
challenges the "multi-chip 
solution." Z8-based designs 
minimize chip-count while offering 
a configuration that can be easily 


The New Standard For 
Single-Chip Microcomputers 


September 1983 


expanded to meet the require- 
ments of enhancement options and 
future improvements. 
The Z8 Family encompasses the 


whole spectrum of system develop- 
ment, from prototyping to full pro- 
duction. For prototyping and pre- 
production, or where code flexibil- 
ity is important,· the Z8603 and 
Z8613 Protopack EPROM-based 
parts are the most appropriate. The 
ROM-based Z8601 and Z8611 
microcomputers are used in high- 
volume production applications 
after the software has been 
perfected. The Z8603 is pin- 
compatible with the Z8601, and the 
Z8613 is compatible with the 
Z8611. 
For ROMless applications, two 
versions of the Z8 microcomputer 
are available: the 40-pin Z8681 and 
Z8682 ROM less microcomputers. 
In addition, there is a military ver- 
sion of the Z8611 4K ROM device, 
available in both 40-pin ceramic 
and 44-pin lead less chip carrier 
packages. 


The Z8671 MCU is a complete 


m icrocompute r pre-prog rammed 
with a BASICIDebug interpreter. 
This device, operating with both ex- 
ternal ROM or RAM and on-chip 
memory registers, is ideal for most 
industrial control applications, or 
whenever fast and efficient pro- 
gram development is necessary. 
Dedicated control is the key 
word for Z8 applications. Since 
speed is a prime consideration in 
such applications, the entire Z8 
family is available in both 8 and 12 
MHz versions, supported by either 
of two development tools: the Z8 
DM Development Module and the 
Z-SCAN 8. The DM provides 
elementary ICE capability, and the 
Z-SCAN 8 module provides full In- 
circuit emulation (ICE) capability in- 
cluding trace memory. With these 
tools, the user is equipped for 
practically any type of Z8 
microcomputer development. 
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Z8 Family of Products 


ROM 
Programmable 
Part 
Capacity 
1/0 Pins 
Dedicated 
PCB 
Product 
Number RAM 
(Bytes) 
UART 
(max.) 
1/0 Pins 
Footprint 
Comments 


2K ROM 
28601 
128 
2K 
H 
32, 4 ports 
8 Power, 
40-Pin 
Masked ROM part, used pri- 


Control 
marily for high-volume produc- 
tion. 


2K Protopack 
28603 
128 
0 
H 
32,4 ports 
8 Power, 
40-Pin 
Piggyback part used where 


Control plus 
program flexibility is required 
24 EPROM 
(prototyping). 


,4K ROM 
28611 
128 
4K 
H 
32,4 ports 
8 Power, 
40-Pin 
Masked ROM part, used pri- 


Control 
marily for high-volume produc: 
tion. 


4K Develop- 
28612 
128 
0 
H 
32,4 ports 
8 Power, 
64-Pin 
ROMless part used primarily 
ment part 
Control plus 
in development systems. 
24 external 


memory 


4K Protopack 
28613 
128 
0 
H 
32,4 ports 
8 Power, 
40-Pin 
Piggyback part used 'Nhere 
Control plus 
program flexibility is required 
24 EPROM 
(prototyping). 


BASICI 
28671 
128 
2K 
H 
24,3 ports 
8 Power, 
40-Pin 
BASICIDebug part used in 
Debug 
Control 
low-volume applications. 


ROM less 
286811 
128 
0 
H 
24, 3 ports 
8 Power, 
40-Pin 
Low-cost ROMless production 
28682 
Control plus 8 
part with reduced 110. Pro- 
external 
gram memory is external. 


memory 


28-UPC 
28090 
256 
2K 
S 
24, 3 ports 
8 Power, 
40-Pin 
Masked ROM part, master 


Control plus 8 
CPU bus is 2-BUS compatible. 


master bus 


28-UPC 
28590 
256 
·2K 
S 
24,3 ports 
8 Power, 
40-Pin 
Masked ROM part, master 


Control plus 8 
CPU bus is general-purpose. 
master bus 


28-UPC 
28094 
256 
0 
S 
24,3 ports 
8 Power, 
40-Pin 
Piggyback part used where· 
Control plus 8 
program flexibility is needed. 
master CPU 
Prototypes, 2-BUS compatible. 


24, RAMI 


PROM 


28-UPC 
28594 
256 
0 
S 
24,3 ports 
8 Power, 
40-Pin 
Piggyback part used where 


Control plus 8 
program flexibility is needed. 
master CPU 
Prototypes, general-purpose. 
24, RAMI 


PROM 


H = Hardware 
S = Software 
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Zilog 


Features 


General 
Description 


2037 -00 I. 002 


m Complete microcomputer, 2K bytes of ROM, 


128 bytes of RAM, 32 I/O lines, and up to 
62K bytes addressable external space each 
for program and data memory. 


a 144-byte register file, including 124 
general-purpose registers, four I/O port 
registers, and 16 status and control 
registers. 


lJ Average instruction execution time of 
1.5 JLs, maximum of 3 JLS. 


[] Vectored, priority interrupts for I/O, 


counter/timers, and UART. 


The Z8601 microcomputer introduces a new 
level of sophistication to single-chip architec- 
ture. Compared to earlier Single-chip micro- 
computers, the Z8601 offers faster execution; 
more efficient use of memory; more sophisti- 
cated interrupt, input/output and bit-manipula- 
tion capabilities; and easier system expansion. 


Under program control, the Z8601 can be 
tailored to the needs of its user. It can' be con- 


PORT 0 
(NIBBLE 


PROGRAMMABLE) 


110 OR A,-A" 


PORT 1 


(BYTE 


PROGRAMMABLE) 


110 OR ADo-AD, 


Figure 1. Pin Functions 


PORT 2 
(BIT PRO· 
GRAMMABLE) 
110 


PORT 3 
(FOUR INPUT; 
FOUR OUTPUT) 
SERIAL AND 
PARALLEL 110 
AND CONTROL 


~8® Fammily @f 
iVJiCl(WHCOiillPUileJi 
1s 


~8$®@ 11 
0 ~g®@3 


Je>ll(UHdl lief 
Spea:iiiiicali@l1l1 


September 1983 


28601 Single-Chip Microcomputer with 2K ROM 
28603 Prototyping Device with EPROM Interface 


El Full-duplex UART and two programmable 
8-bit counter/timers, each with a 6-,bit pro- 
grammable prescaler. 


(J R~gister Pointer so that short, fast instruc- 
tions can access any of nine working 
register groups in 1 JLS. 


lJ On-chip oscillator that accepts crystal or ex- 
ternal clock drive. 


C Low-power standby option which retains 
contents of general-purpose registers. 


[J Single + 5 V power supply-all pins TTL- 
compatible. 


figured as a stand-alone microcomputer with 
2K bytes of internal ROM, a traditional micro- 
processor that manages up to 124K bytes of 
external memory, or a parallel-processing ele- 
ment in a system with other processors and ' 
peripheral controllers linked by the Z-BUS. In 
all configurations, a large number of pins 
remain available for I/O. 


+5V 
40 
P3, 


XTAL2 
P3, 


XTALl 
P2, 


P3, 
P2, 


P30 
P2, 


RESET 
P2. 


RIW 
P2, 
os 
P2, 


AS 
P2, 


P3, 
P20 


GND 
P3, 


P3, 
P3. 


POo 
Pl, 


PO, 
Pl, 


PO, 
Pl, 


PO, 
Pl. 


PO. 
Pl, 


PO, 
Pl, 


PO, 
Pl, 


PO, 
Plo 


Figure 2. Pin Assignments 
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Architecture 
Z8601 architecture is characterized by a 
microprocessor that can address 124K bytes of 
_ external memory. 


Pin 
Description 
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flexible I/O scheme, an efficient register and 
address space structure and a number of 
ancillary features that are helpful in many 
applications. 
. 
Microcomputer applications demand power- 
ful I/O capabilities. The Z8601 fulfills this with 
32 pins dedicated to input and output. These 
lines are grouped into four ports of eight lines 
each and are configurable under software con- 
trol to provide timing, status signals, serial or 
parallel I/O with or without haridshake, and an 
address/data bus for interfacing external 
memory. 
Because the multiplexed address/data bus is 
merged with the I/O-oriented ports, the Z8601 
can assume many different memory and I/O 
configurations. These configurations range 
from a self-contained microcomputer to a 


OUTPUT 
Vee 
GND 


! ! 


IlllUl1 


Three basic address spaces are available to 
support thi's wide range of configurations: pro- 
gram memory (internal and external), data 
memory (external) and the register file (Inter- 
nal). The 144-byte random-access register file 
is composed of 124 general-purpose registers, 
four I/O port registers, and 16 control and 
status registers. 
To unburden the program from coping with 
real-time problems such as serial data com- 
munication and counting/timing, an asynchro- 
nous receiver/transmitter (UART) and two 
counter/timers with a large number of user- 
selectable modes are offered on-chip. Hard- 
ware support for the UART is minimized 
because one of the on-chip timers supplies the 
bit rate. 


1/0 
(BIT PROGRAMMABLE) 


ADDRESS OR 1/0 
(NIBBLE PROGRAMMABLE) 
ADDRESSIDATA OR 1/0 
(BYTE PROGRAMMABLE) 


Figure 3. Functional Block Diagram 


AS. Address Strobe (output, active Low). 
Address Strobe is pulsed once at the begin- 
ning of each machine cycle. Addresses output 
via Port 1 for. all external program or data 
memory transfers are valid at the trailing edge 
of AS. Under program control, AS can be 
placed in the high-impedance state along with 
Port,s 0 and 1, Data Strobe and Read/Write. 


DS. Data Strobe (output, active Low). Data 
Strobe is activated once for each external 
memory transfer. 


POO-P07' P1o-PI7' P20-P27' P30-P37. 1/0 Port· 
Lines (input/outputs, TTL-compatible). These 
32 lines are divided into four 8-bit I/O ports 
that can be configured under program control 


for I/O or external memory interface. 


RESET. Reset {input, active Low); RESET ini- 
tializes the 28601. When RESET is deactivated, 
program execution begins from internal pro- 
gram location OOOCH. 
R/W. Read/Write (output). R/W is Low when 
the 28601 is writing to external program or 
data memory. 
XTALl, XTAL2. Crystall, Crystal 2 (time-base 
input and output). These pins connect a 
parallel-resonant crystal (8 or 12 MHz max- 
imum) or an external single-phase clock (8 or 
12 MHz maximum) to the on-chip clock 
oscillator and buffer. 


2037-003 


Address 
Spaces 


Program Memory. The 16-bit program 
counter addresses 64K bytes of program 
memory space. Program memory can be 
located in two areas: one internal and the 
other external (Figure 4). The first 2048 bytes 
consist of on-chip mask-programmed ROM. At 
addresses 2048 and greater, the 28601 
executes external program memory fetches. 
The first 12 bytes of program memory are 
reserved for the interrupt vectors. These loca- 
tions contain six 16-bit vectors that correspond 
to the six available interrupts. 
Data Memory. The 28601 can address 62K 
bytes of external data memory beginning at 


Location of 
flrstbyteot 
Instruction 


executed 
aHarrese' 


Interrupt 
Vector 


(Lower Byte) 


Interrupt 


Vector 


(Upper Byte) 


5535 


EXTERNAL 


ROM OR RAM 


2048 
2047 


ON·CHIP 
ROM 


~ 
~------------ 


11 
lRa5 


10 
IRaS 


9 
IRa4 


8 
IRa4 


7 
IRa3 


6 
IRa3 


51" 
IRa2 


4~ 
IRa2 


3 
IRal 


2 
IRal 


1 
IRaO 


0 
IRaO 


Figure 4. Program Memory Map 


LOCATION 


255 


254 


253 


252 


251 


250 


249 


248 


247 


246 


245 


244 


243 


242 


241 


240 


127 


STACK POINTER (BITS 7-0) 


STACK POINTER (BITS 15-8) 


REGISTER POINTER 


PROGRAM CONTROL FLAGS 


INTERRUPT MASK REGISTER 


INTERRUPT' REaUEST REGISTER 


INTERRUPT PRIORITY REGISTER 


PORTS 0-1 MODE 


PORT 3 MODE 


PORT 2 MODE 


TO PRESCALER 


TIMER/COUNTER 0 


T1 PRESCALER 


TIMER/COUNTER 1 


TIMER MODE 


SERIAL I/O 


NOT 
IMPLEMENTED 


GENERAL·PURPOSE 
REGISTERS 


PORT 3 


PORT 2 


PORT 1 


PORT 0 


IDENTIFIERS 


SPL 


SPH 


RP 


FLAGS 


IMR 


IRa 


IPR 


P01M 


P3M 


P2M 


PREO 


TO 


PREl 


T1 


TMR 


SIO 


P3 


P2 


Pl 


PO 
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location 2048 (Figure 5). External data 
memory may be included with or separated 
from the external program memory space. 
DM, an optional I/O function that can be 
programmed to appear on pin P34, is used to 
distinguish between data and program 
memory space. 
Register File. The 144-byte register file 
includes four I/O port registers (RO-R3), 124 
general-purpose registers (R4-R127) and 16 
control and status registers (R240-R255). These 
registers are assigned the address locations 
shown in Figure 6. 
28601 instructions can access registers 


655351"'""----------, 


EXTERNAL 
DATA 


MEMORY 


~~:~ 1-----------1 


NOT ADDRESSABLE 


Figure 5. Data Memory Map 


1-~;:::=+------......,255 
-{ 
~ 
- 
~'-------I 


..... ---------... 240 


The upper n!bble 01 the reglsterflle address 
provided by the register pointer speCifies 
the actlveworking·reglstergroup. 


SPECIFIED WORKING· 
REGISTER GROUP 


12 


...-- 


The lower 
nibble 01 
the-register 
file address 
provided by 
the Instruction 
points to the 
specilied 
register. 


15 


1-------------3 
I/O PORTS 


Figure 7. The Register Pointer 
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Address 
Spaces 
( Continued) 


Serial 
Input/ 
Output 


Counter/ 
Timers 


490 


directly or indirectly with an 8-bit address 
field. The 28601 also allows short 4-bit register 
addressing using the Register Pointer (one of 
the control registers). In the 4-bit mode, the 
register file is divided into nine working- 
register groups, each occupying 16 contiguous 
locations (Figure 7). The Register Pointer 
addresses the starting location of the active 
working-register group. 


Port 3 lines P30 and P37 can be programmed 
as serial I/O lines for full-duplex serial asyn- 
chronous receiver/transmitter operation. The 
bit rate is controlled by Counter/Timer 0, with 
a maximum rate of 62.5K bits/second for 8 
MHz and 94.8K bits/second for 12 MHz. 
The 28601 automatically adds a start bit and 
two stop bits to transmitted data (Figure 8). 
Odd parity is also available as an option. Eight 
data bits are always transmitted, regardless of 


Transmitted Data 
(No Parity) 


LSTART BIT 
'------EIGHr DATA BITS 


TWO STOP BITS 


Transmitted Data 
(With Parity) 


I 
SP I 
SP I P I 061 051 0,1 031 0,1 0, I 
do I ST I 
'1'1 
LSTARTBIT 
'-----SEVEN DATA BITS 
L---------OOO PARITY 


TWO STOP BITS 


Stacks. Either the internal register file or the 
external data memory can be usedfor the 
stack. A 16-bit Stack Pointer (R254 and R255) 
is used for the external stack, which can reside 
anywhere in data memory between locations 
2048 and 65535. An 8-bit Stack Pointer (R255) 
is used for the internal stack that resides within 
the 124 general-purpose registers (R4-R127). 


parity selection. If parity is enabled, the eighth 
bit is the odd parity bit. An interrupt request 
(IRQ4) is generated on all transmitted 
characters. 
Received data must have a start bit, eight 
data bits and at least one stop bit. If parity is 
on, bit 7 of the received data is replaced by a 
parity error flag. Received characters generate 
the IRQ3 interrupt request. 


Received Data 
(No Parity) 


I~I~I~I~I~I~I~I~I~I~I 


1 


LSTART BIT 
'------EIGHT DATA BITS 
'----------ONE STOP BIT 


Received Data 
(With Parity) 


1~lpl~I~I~I~I~I~I~I~1 
II,- 


_LSTARTBIT 
'-----SEVEN DATA BITS 


PARITY ERROR FLAG 


'----------ONE 
STOP BIT 


Figure 8. Serial Data Formats 


Ths'28601 contains two 8-bit programmable 
counter/timers (To and Tl), each driven by its 
own 6-bit programmable prescaler. The Tl 
prescaler can be driven by internal or external 
clock sources; however, the To pres caler is 
driven by the internal clock only. 
The 6-bit prescalers can divide the ipput fre- 
quency of the clock source by any number 
from 1 to 64. Each pres caler drives its counter, 
which decrements the value (1 to 256) that has 
been loaded into the counter. When the 
counter reaches the end of count, a timer 
interrupt request-IRQ4 (To) or IRQ5 (Tl)-is 
generated. 
The counters can be started, stopped, 
restarted to continue, or restarted from the 
initial value. The counters can also be pro- 
grammed to stop upon reaching zero (single- 
pass mode) or to automat'ically reload the 


initial value and continue counting (modulo-n 
continuous mode). The counters, but not the 
prescalers, can be read any time without 
disturbing their value or count mode. 


, The clock source for T 1 is user-definable and 
can be the internal microprocessor clock 
(4 MHz maximum for the 8 MHz device and 6 
MHz maximum for the 12 MHz device.) divid- 
ed by four, or an external signal input via Port 
3. The Timer Mode regi~ter configures the ex- 
ternal timer input as an external clock (1 MHz 
maximum), a trigger input that can be retrig- 
gerable or non-retriggerable, or as a gate in- 
put for the internal clock. The counter/timers 
can be programmably cascaded by connecting 
the To output to the input of Tl. Port 3 line P36 
also serves as a timer output (TOUT) through 
which To, Tl or the internal clock can be out- 
put. 


2037-009 


I/O Ports 


2037-008 


The 28601'has 32 lines dedicated to input 
and output. These lines are grouped into four 
ports of eight lines each and are configurable 
as input, output or address/data. Under soft- 
ware control, the ports can be programmed to 


Port 1 can be programmed as a byte 1/0 


port or as an addressldata port for interfacing 
external memory. When used as an 1/0 port, 
Port 1 may be placed under handshake con- 
trol. In this configuration, Port 3 lines P33 and 
P34 are used as the handshake controls RDY 1 
and DAVI (Ready and Data Available). 
Memory locations greater than 2048 are 
referenced through Port 1. To interface exter- 
nal memory, Port 1 must be programmed 
for the multiplexed Address/Data mode. If 
more than 256 external locations are required, 
Port 0 must output the additional lines. 


Port 1 can be placed in the high-impedance 
state along with Port 0, AS, DS and RIW, allow- 


Port 0 can be programmed as a nibble 1/0 


port, or as an address port for interfacing 
external memory. When used as an 1/0 port, 
Port 0 may be placed under handshake con- 
trol. In this configuration, Port 3 lines P32 and 
P3s are used as the handshake controls DA Vo 
and RDYo. Handshake signal assignment is 
dictated by the 1/0 direction of the upper 
nibble P04-P07. 


For external memory references, Port 0 can 
provide address bits As-All (lower nibble) or 
As-AIS (lower and upper nibble) depending 
on the required address space. If the address 
range requires 12 bits or less, the upper nibble 
of Port 0 can be programmed independently as 


Port 2 bits can be programmed inde- 
pendently as input or output. The port is 
always available for I/O operations. In addi- 
tion, Port 2 can be configured to provide 
open-drain outputs. 
Like Ports 0 and 1, Port 2 may also be 
placed under handshake control. In this con- 
figuration, Port 3 lines P31 and P36 are used as 
the handshake controls lines DA V 2 and RDY 2. 
The handshake signal assignment for Port 3 
lines P31 and P36 is dictated by the direction 
(input or output) assigned to bit 7 of Port 2. 


Port 3 lines can be configured as I/O or con- 
trol lines. In either case, the direction of the 
eight lines is fixed as four input (P30-P33) and 
four output (P34-P37)' For serial I/O, lines P30 
and P37 are programmed as serial in and serial . 
out respectively. 


Port 3 can also provide the following control 
functions: handshake for Ports 0, 1 and 2 
(DAVand RDY); four external interrupt 
request signals (IRQo-IRQ3); timer input and 
output signals (TIN and Tour) and Data 
Memory Select (DM). 


provide address outputs, timing, status signals, 
serial 1/0, and parallel 1/0 with or without 
handshake. All ports have active pull-ups and 
pull-downs compatible with TTL loads. 


ing the 28601 to share common resources in 
multiprocessor and DMA applications. Data 
transfers can be controlled by assigning P33 
as a Bus Acknowledge input and P34 as a Bus 
Request output. 


PORT 1 
(1/0 OR ADo-AD7) 


Figure 9a. Port 1 


1/0 while the lower nibble is used for address- 
ing. When Port 0 nibbles are defined as 
address bits, they can be set to the high- 
impedance state along with Port 1 and the con- 
trol signals AS, DS and RIW. 


} 


PORT 0 
(110 OR As-A,.! 


Figure 9b. Port 0 
- 


PORT 2(110) 


} 
HANDSHAKE CONTROLS 
DAV2 AND RDY2 
(P3, AND P3sl 


Figure 9c. Port 2 


- 
PORT 3 
(110 OR CONTROL) 


Figure 9d. Port 3 
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Interrupts 


Clock 


Power Down 
Standby 


.. Option 


492 


The 28601 allows six different interrupts from 
eight sources: the four Port 3 lines P30-P33, 
Serial In,. Serial Out, and the two counter/ 
timers. These interrupts are both maskable and 
prioritized. The Interrupt Mask register glob- 
ally or individually enables or disables the six 
interrupt requests. When more than one inter- 
rupt is pending, priorities are resolved by a 
programmable priority encoder that is con- 
trolled by the Interrupt Priority register. 
All 28601 interrupts are vectored. When an 
interrupt request is granted, an interrupt 
machine cycle is entered. This disables all 


The on-chip oscillator has a high-gain, 
parallel-resonant amplifier for connection to a 
crystal or to any suitable external clock source 
(XTALl = Input, XTAL2 = Output). 
The crystal source is connected across 
XTALl and XTAL2, using the recommended 
capacitors (Cl ::5 15 pF) from each pin to 


The low-power standby mode allows power 
to be removed without losing the contents of 
the 124 general-purpose registers. This mode 
is available to the user asa bonding option 
whereby pin 2 (normally XTAL2) is replaced 
by the VMM (standby) power supply input. This 
necessitates the use of an external clock 
generator (input = XTALl) rather than a 
crystal source. 
The removal of power; 'whether intended or 


due to power failure, must be preceded by a 
software routine that stores the appropriate 
status into the register file. Figure 10 shows 


subsequent interrupts, saves the Program 
Counter and status flags, and branches to the 
program memory vector location reserved for 
that· interrupt. This memory location and the 
next byte contain the 16-bit address of the 
interrupt service routine for that particular 
interrupt request. 
Polled interrupt systems are also supported. 
To accommodate a polled structure, any or all 
of the interrupt inputs can be masked and the 
Interrupt Request register polled to determine 
which of the interrupt requests needs service. 


ground. The specifications for the crystal are 
as follows: 


• AT cut, parallel resonant 
• Fundamental type, 8/12 MHz maximum 
• Series resistance, Rs ::5 100 n 


'the recommended circuit for a battery back-up 
supply system. 


+5V o----__ 
-~ 
Voo 


Z8801 


J 


Figure 10. Recommended Driver Circuit 


for Power Oown Operation 


2037-010 


Z8603 
Protopack 
Emulator 


Instruction 
Set 
Notation 


2037-012 


The Z8603 MPE (Protopack) is used tor 
prototype development and preproduction of 
mask-programmed applications. The Protopack 
is a ROMless version of the standard Z8601, 
housed in a pin-compatible 40-pin package 
(Figure 11). 
To provide pin compatibility and inter- 
changeability with the standard mask- 
programmed device, the Protopack carries 
(piggy-backs) a 24-pin socket for a direct 
interface to program memory (Figure 1). The 
24-pin socket is equipped with 11 ROM 
address lines, 8 ROM data lines and necessary 


Figure 11. The Z8603 Microcomputer Protopack Emulator 


Addressing Modes. The follOWing notation is used 
to describe the addreSSing modes and instruction 
operations as shown in the instruction summary. 


IRR 


Irr 
X 
DA 
RA 
1M 
R 


Indirect register pair or indirect working-register 
pair address 
Indirect working-register pair only 
Indexed address 
Direct address 
Relative address 
Immediate 
Register or working-register address 
Working-register address only 
IR 
Indirect-register or indirect working-register 
address 
Ir 
Indirect working-register address only 
RR 
Register pair or working register pair address 


Symbols. The following symbols are used in 
describing the instruction set. 
dst 
Destination location or contents 
src 
Source location or contents 
cc 
Condition code (see list) 


@ 
Indirect address prefix 


SP 
Stack pointer (control registers 254-255) 
PC 
Program counter 


FLAGS Flag register (control register 252) 
RP 
IMR 
Register pointer (control register 253) 
Interrupt mask register (control register 251) 


control lines for interface to 2716 EPROM for 
the first 2K bytes of program memory. 


Pin compatibility allows the user to design 
the pc board for a final 40-pin mask- 
programmed Z8601, and, at the same time, 
allows the use of the Protopack to build the 
prototype and pilot production units. When the 
final program is established, the user can then 
switch over to the 40-pin mask-programmed 
Z8601 for large volume production. The Proto- 
pack is also useful in small volume applica 
tions where masked ROM setup time, mask 
charges, etc., are prohibitive and program 
flexibility is desired. 
Compared to the conventional EPROM 


versions of the single-chip microcomputers, 
the Protopack approach offers two main 
advantages: 


L1 Ease of developing various programs during 
the prototyping stage. For instance, in 
applications where the same hardware 
configuration is used with more than one 
program, the Z8603 Protopack allows 
economical program storage in separate 
EPROMs (or PROMs), whereas the use of 
separate EPROM-based single-chip 
microcomputers is more costly. 


C Elimination of long lead time in procuring 


EPROM-based microcomputers. 


Assignment of a value is indicated by the symbol 


"-". For example, 
dst - 
dst + src 
indicates that the source data is added to the 
destination data and the result is stored in the 
destination location. The notation "addr(n)" is used 
to refer to bit "n" of a given location. For example, 
dst (7) 


refers to bit 7 of the destination operand. 


Flags. Control Register R252 contains the following 
six flags: 


C 
Carry flag 
Z 
Zero flag 


S 
Sign flag 


V 
Overflow flag 
D 
Decimal-adjust flag 
H 
Ha.lf-carry flag 


Affected flags are indicated by: 
o 
Cleared to zero 
Set to one 


11 
Set or cleared according to operation 
Unaffected 


X 
Undefined 
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Condition 
Codes 
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Value 


1000 
0111 
1111 
0110 
1110 
1101 
0101 
0100 
1100 
0110 
1110 
1001 
0001 
1010 
0010 
1111 
0111 
1011 
0011 
0000 


Mnemonic 


C 
NC 
Z 
NZ 
PL 
MI 
OV 
NOV 
EQ 
NE 
GE 
LT 
GT 
LE 
UGE 
ULT 
UGT 
ULE 


OPC 
I 
1--:::';dS"'::t:'-~ OR 11 1 1 01 
dst 


OPC 
VALUE 


'--.....;...;.;..;:.~--' OR 11 1 1 01 


dst 
1 OPC 
VALUE 
I 
dStlCCR~ OPC 


dSI 


Always true 
Carry 
No carry 
Zero 
Not zero 
Plus 
Minus 
Overflow 
No overflow 
Equal 
Not equal 


Meaning 


Greater than or equal 
Less than 
Greater than 
Less than or equal 
Unsigned greater than or equal 
Unsigned less than 
Unsigned greater than 
Unsigned less than or equal 
Never true 


OPC 


OPC 


CCF, DI, EI, IRET, NOP, 
RCF, RET, SCF 


INCr 


One-Byte Instructions 


JP, CALL (Indirect) 


C 
1 
C 
a 


Z = 1 
Z = a 
s = a 
S = 1 
V = 1 
V = a 
Z = 1 
Z = a 


Flags Set 


(8 XOR V) = a 
(8 XOR V) = 1 
[Z OR (8 XOR V)] 
a 


[Z OR (8 XOR V)] 
1 
C = a 
C = 1 
(C = a AND Z = 0) 
(C OR Z) = 1 


ADC, ADD, AND, cp, 
LD, OR, SBC, SUB, 
TCM, TM, XOR 


1--_"::":":_-01 OR 111 1 01 
dst 


ADC, ADD, AND, CP, 
LD, OR, SBC, SUB, 
TCM, TM, XOR 
SRP 


ADC, ADD, AND, 
CP, OR, SBC, SUB, 
TCM, TM, XOR 


LD, LDE, LDEI, 
LDC, LDCI 


LD 


LD 


DJNZ, JR 


LD 


LD 


JP 


CALL 


Two-Byte Instructions 
Three-Byte Instructions 


Figure 12~ Instruction Formats 
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Instruction 
Instruction 
Addr Modo 
Opcodo Flags Affocted 
Instruction 
Addr Modo 
Opcodo Flags Affected 


Summary 
and Operation 
dst 
Byte 
and Operation 
dst 
Byte 
arc 
(Hox) 
CZSVDH 
src 
(Hex) 
CZSVDH 


ADC dst,src 
(Note 1) 
10 
o • 
LDE dst,src 
r 
lrr 
82 
------ 
dst - dst + arc + C 
dst - 
src 
lrr 
92 


ADD dst,src 
(Note 1) 
00 
• 0 • 
LDEI dst,src 
lr 
lrr 
83 
------ 
dst - 
dst + src 
dst - 
src 
lrr 
lr 
93 


AND dst,src 
(Note 1) 
50 
0 
r - r + 1; rr - rr + 1 


dst - 
dst AND src 
NOP 
FF 
------ 


CALL dst 
DA 
D6 
------ 
OR dst,src 
(Note 1) 
40 
- 
• • 0 - - 
SP - 
SP - 2 
IRR 
D4 
dst - dst OR src 


@SP - PC; PC - dst 
POP dst 
R 
50 
------ 
CCF 
EF 
* - - - - - 
dst - 
@SP 
IR 
51 


C - 
NOT C 
SP - 
SP + 1 


CLR dst 
R 
BO 
PUSH src 
R 
. 70 


dst - 
0 
IR 
Bl 
SP - SP-l; @SP - src 
IR 
71 


COM dst 
R 
60 
- . . 0-- 
RCF 
CF 
o - - - - - 
dst - 
NOT dst 
IR 
61 
C-O 


CP dst,src 
(Note 1) 
AD 
RET 
AF 
------ 
dst - src 
PC - 
@ SP; SP - SP + 2 
N 


DA dst 
R 
40 
• X 
RL dst 
CO 
~ 
R 
90 
m 
dst - 
DA dst 
IR 
41 
IR 
91 
.... 
DEC dst 
R 
00 
- * * * - - 
RLC dst lIiJ=E:i)J R 
10 
- 
dst - 
dst - 1 
IR 
01 


c 
, 
0 
lR 
11 
W 


I 
RR dst lQ] l), 
.~ 1~ 
EO . . . 
• 
DECW dst 
RR 
80 
- * * *-- 
El 
f'!a 


dst - 
dst·- 1 
IR 
81 
eI 


RRC dst lIiJ=E:i)J R 
CO 
.. - - 
DI 
c 
, 
0 
lR 
Cl 
IMR (7) - 
0 
8F 
------ 
SBC dst,src 
(Note 1) 
30 
• • 1 . 


DJNZ r,dst 
RA 
rA 
dst - dst - src - C 
------ 
r - 
r - 1 
r=O-F 
SCF 
DF 
1 - - - 
if r '* 0 
C-1 
PC - 
PC + dst 
SRA dst lQ]~~ 
DO 
Range: + 127, -128 
• • • 0 
D1 
EI 
9F 
------ 
SRP src 
1m 
31 
------ 
IMR (7) - 
1 
RP - 
src 
INC dst 
rE 
-***-- 
SUB dst,src 
(Note 1) 
20 
• • 1 . 
dst - 
dst + 1 
r=O-F 
dst - dst - src 
R 
20 


lR 
21 
SWAP dst @ 
R 
FO 
X • • X - 
- 
IR 
F1 
INCW dst 
RR 
AO 
-***-- 
dst - 
dst + 
IR 
Al 
TCM· dst,src 
(Note 1) 
60 
- 
• • 0 


IRET 
BF 
* * * * * * 


(NOT dst) AND src 


FLAGS - 
@SP; SP - SP + 1 
TM dst, src 
(Note 1) 
70 
- 
• • 0 
PC - 
@SP; SP - SP + 2; IMR(7) - 
1 
dst AND src 


JP cc,dst 
DA 
cD 
------ 
XOR dst,src 
(Note 1) 
Bo 
• 0 - - 
if cc is true 
c=O-F 
dst - dst XOR src 


PC - 
dst 
IRR 
30 


JR cc,dst 
RA 
cB 
------ 
Nole 1 
if cc is true, 
c=O-F 
These instructions have an identical set of addressing 
PC - PC + dst 
Range: + 127, -128 
modes, which ar~ encoded for brevity. The first opcode 
nibble is found in the instruction set table above. The 
LD dst,src 
1m 
rC 
------ 
second nibble is expressed symbolically by a 0 in this 
dst - 
src 
r 
R 
r8 
table, and its value is found in tho follOWing table to the 
R 
r9 
left of the applicable addreSSing mode pair. 


r=O-F 
For example, to determine the opcode of an ADC 
r 
X 
C7 
instruction use the addreSSing modes r (destination) and 
X 
r 
D7 
Ir (source). The result is 13. 
r 
lr 
E3 
lr 
r 
F3 
R 
R 
E4 
Addr Modo 
Lower 
R 
IR 
E5 
Opcode Nibble 
R 
1m 
E6 
dst 
src 
IR 
1m 
E7 
[l] 
IR 
R 
F5 


LDC dst,src 
r 
lrr 
C2 
------ 
lr 
@] 


dst - 
src 
lrr 
D2 
R 
R 
[i] 


LDCI dst,src 
lr 
lrr 
C3 
------ 
R 
1R 
lID 


dst - 
src 
1rr 
lr 
D3 
R 
1M 
lID 
r - r + 1; rr - rr + 1 
IR 
1M 
[1] 


8085-00~ 
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Registers 
R240SI0 
Serial 110 Register 
(FOH; ReadlWrite) 


I 0,\ 0.\ 0,\ 0.\ 03 \ O 
2 \ 0, \ 
Do I 


'------SERIAL DATA (Do = LSB) 


R241 TMR 
Timer Mode Register 
(FIH; ReadlWrite) 


NOT USED = 00 ~ 
1 = LOAD To 
TOUT MODES j 
llli~o = NO FUNCTION 


~~ g~~ : ~~ 
0 = DISABLE To COUNT 
INTERNAL CLOCK OUT = 11 
. 
1 = ENABLE To COUNT 


T MODES 
0 = NO FUNCTION 


EXTERNAL CLOCK INP'OT = 00 
1 = LOAD T, 


GATE INPUT = 01 
0 = DISABLE T, COUNT 


(NON.R~~~~g~~~~:~i) = 10 
1 = ENABLE T, COUNT 
TRIGGER INPUT = 11 
(RETRIGGERABLE) 


R242 Tl 
Counter Timer 1 Register 
(F2H; ReadlWrite) 


T, INITIAL VALUE (WHEN WRITTEN) 
L-----(RANGE 1-256 DECIMAL 01-00 HEX) 


T, CURRENT VAlliE (WHEN READ) 


R243 PREI 
Prescaler.l Register 
(F3H; Write Only) 


[ 


C~~NJ, ~~DGELE.PASS 


1 = T, MDDULO·N 


CLOCK SOURCE 


1 = T, INTERNAL 
o = T, EXTERNAL TIMING INPUT 


(T'N) MODE· 


PRESCALER MODULO 
'-------(RANGE: 1-64 DECIMAL 
01-00 HEX) 


R244 TO 


Counter/Timer 0 Register 
(F4H; ReadlWrite) 


To INITIAL VALUE (WHEN WRITTEN) 
'------(RANGE: 1-256 DECIMAL 01-00 HEX) 
To CURRENT VALUE (WHEN READ) 


R245 PREO 


Prescaler 0 Register 
(F5H; Write Only) 
l 


COUNTMODE 
o = To SINGLE·PASS 
1 = To MODULO·N 


RESERVED 


PRESCALER MODULO 
'-------(RANGE: 1-64 DECIMAL 
01-00 HEX) 


R246 P2M 
Port 2 Mode Rogister 
(F6H ; Write Only) 


I 0,\ 0.\ 0,\ 0.\ 03 \ O 
2 \ 0, \ 
Do I 


P2o-P2, 110 DEFINITION 
L-____ 0 DEFINES BIT AS OUTPUT 


1 DEFINES BIT AS INPUT 


R247 P3M 
Port 3 Modo Register 
(F7H ; Write Only) 


~~ 


O PORT 2 PULL·UPS OPEN DRAIN 
1 PORT 2 PULL·UPS ACTIVE 


RESERVED 
o P32 = INPUT 
P35 = OUTPUT 


1 P32 = MVO/RDYO P3S = RDYO/DAVli 


00 P33 = INPUT 
P34 = OUTPUT 


~ ~} P33 = INPUT 
P34 = IlM 


1 1 P33 = DAVl/RDYl P34 = RDYl/DAVl 


'--------~ 
~~~ : ~J!Jfo'~~ ~;: ~ ~~~~~~~2UT) 
'--------- ~ ~~g : ~N~~IL IN 
~~~ ~ ~~~~~T OUT 
'--________ 
~ ~!=:~~ g~F 


Figure13. Control Regist~rs 
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Registers 
(Continued) 
R248 POIM 
Port 0 and I Mode Rogistor 
(F8H; Write Only) 


I 0,1 0.1 0.1 0.1 031 021 0, I 
Do I 


OUTPUT = 00 
. 
L 
00 = OUTPUT 


INPUT = 01 
01 = INPUT 
A'2-A" = lX 
lX = A.-A" 


PO.-PO, MODE:] ~-r 
POO-P03 MODE 


EXTERNAL MEMORY TIMING 
STACK SELECTION 


NORMAL .. 0 
0 = EXTERNAL 
EXTENDED = 1 
1 = INTERNAL 


Plo-Pl, MODE 


00 = BYTE OUTPUT 
01 = BYTE INPUT 
10 = ADo-AD, 
11 .. HIGH·IMPEDANCE ADo-AD,. 


AS. OS. RtW. As-A". A'2-A15 
IF SELECTED 


R2491PR 


Interrupt Priority Roglster 
(F9H; Write Only) 


I~I~I~I~I~I~I~I~I 


RESERVED :J I T 1 
INTERRUPT GROUP PRIORITY 
RESERVED = 000 
IRQ3. IRQS PRIORITY (GROUP A) 
C > A > B = 001 
o = IRQS > IRQ3 
A > B > C = 010 


1 = IRQ3 > IRQS 
A > C > B = 011 


IRQO. IRQ2 PRIORITY (GROUP B) 
o = IRQ2 > IRQO _____ -J 
1 = IRQO > IRQ2 


IRQ1, IRQ4 PRIORITY (GROUP C) 
o = IRQ1 > IRQ4 ---------1 
1 = IRQ4 > IRQ1 


B > C > A = 100 
C> B > A = 101 
B > A > C = 110 
RESERV~D = 111 


R250 IRQ 
Intorrupt Request Reglstor 
(FAH; ReadlWrite) 


I 0,1 0.1 0.1 0.1 031 021 0, I Do I 


RESERVED ==r- 
c= 
IRQO .. P32 INPUT (Do .. IRQO) 
IRQ1 .. P33 INPUT 
IRQ2 - 
P3, INPUT 
IRQ3 .. P30 INPUT. SERIAL INPUT 
IRQ4 .. To. SERIAL OUTPUT 
IRQS = T, 


R2511MR 
Interrupt Mask Register 
(FBH; ReadlWrite) 


I 0,1 0.1 0.1 0.1 031 021 0, I 
Do I 


I. I 
c= 
1 ENABLES IRQO-IRQS 
(Do = IRQO) 
1..------- RESERVED 


1---------1 ENABLES INTERRUPTS 


REGISTER 
POINTER 


Figure 13. Control Registers 


R252 FLAGS 
Flag Rogistor 


(FCH; Read/Write) 


LUSER FLAG F2 


~~~ 


LUSERFLAGF1 


HALF CARRY FLAG 


DECIMAL ADJUST FLAG 


OVERFLOW FLAG 


SIGN FLAG 


ZERO FLAG 


I..------..:.---CARRY FLAG 


R253 RP 


Register Pointer 
(FDH; ReadlWrite) 


I 0,1 0.1 0.1 0.1 03 1 021 0, I Do I 


{:~gJJ 


C=DON'T CARE 


R254 SPH 
Stack Pointor 


(FEH; ReadIWrite) 


R255 SPt 
Stack Pointer 


(FFH; ReadIWrite) 


I 0,1 De I 0.1 0.1 0 31 
021 
0, I Do I 
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Z8601 
Opcode 
Map 


o 


2 


3 


" 


5 


-;c 
6 


GI 
!S 


GI :a 
7 
:9 
:z; .. 
GI 
Po 
8 
Po 
~ 


9 


A 


B 


C 


D 


E 


F 


o 


6,5 
DEC 
Rl 


6,5 
RLC 
Rl 
6,5 
INC 
Rl 


8,0 
IP 
IRRI 
8,5 
DA 
Rl 


10,5 
POP 
Rl 


6,5 
COM 
RI 


10/12,1 
PUSH 
Rz 


10,5 


DECW 


RRI 
6,5 
RL 
Rl 
10,'5 
INCW 


RRI 


6,5 
CLR 
Rl 


6,5 
RRC 
Rl 
6,5 
SRA 
Rl 


6,5 
RR 
Rl 


8,5 


SWAP 


Rl 


6,5 
DEC 
IRI 


6,5 
RLC 
IRl 


6,5 
INC 
IRI 


6,1 
SRP 
1M' 


8,5 
DA 
IRl 


10,5 
POP 
IRI 


6,5 
COM 


IRl 


12/14,1 
PUSH 


IR2 


10,5 


DECW 


IRI 
6,5 
RL 
IRI 


10,5 
INCW 


IRI 


6,5 
CLR 
IRI 


6,5 
RRC 
IRl 


6,5 
SRA 
IRl 


6,5 
RR 
IRI 


8.5 


SWAP 
IRI 


2 
3 


6,5 
6,5 


ADD 
ADD 


II, IZ 
II, lIZ 


6,5 
6,5 
ADC 
ADC 


II, IZ 
Il,IIZ 


6,5 
6,5 


SUB 
SUB 
n,IZ 
II,IIZ 


6,5 
6,5 


SBC 
SBC 
II, IZ 
II, lIZ 


6,5 
6,5 


OR 
OR 
II, 12 
II, lIZ 


6,5 
6,5 
AND 
AND 
n,IZ 
II, lIZ 


6,5 
6,5 
TCM 
TCM 


n,IZ 
II,Il2 


6,5 
6,5 
TM 
TM 


II, 12 
Il,Il2 


12,0 
18,0 


LDE 
LDEI 


II,III2 In,lrl2 


12,0 
18,0 


LDE 
LDEI 


Iz,IIII IIz,IIIl 


6,5 
6,5 
CP 
CP 


n,IZ 
II,Irz 


6,5 
6,5 


XOR 
XOR 
II, rz 
Il,Irz 


12,0 
18,0 


LDC 
LDCI 


n,Irlz IIl,IIl2 


12,0 
18,0 


LDC 
LDCI 


Iz,IIIl Irz, lIn 


6,5 
LD 


II, Irz 


6,5 
LD 
Ill, r2 


Lower Nibble (Hex) 


" 


5 
6 
7 
8 
9 
A 
B 
C 
D 
E 
F 


10,5 
10,5 
10,5 
10,5 
6,5 
6,5 
12/10,5 12/10,0 
6,5 
12/10,0 
6,5 
ADD 
ADD 
ADD 
ADD 
LD 
LD 
DJNZ 
JR 
LD 
JP 
INC 
R2,Rl 
IR2,Rl 
Rl,IM 
IRl,IM 
Il,Rz 
12,Rl 
II,RA 
cc,RA 
Il,IM 
cc,DA 
II 


10,5 
10,5 
10,5 
10,5 
~ 


ADC 
ADC 
ADC 
ADC 


Rz,Rl 
IRz,Rl 
RI,IM 
IRl,IM 
f--- 
10,5 
10,5 
10,5 
10,5 
SUB 
SUB 
SUB 
SUB 
Rz,Rl 
IR2,Rl 
RI,IM 
IRl,IM 
f--- 
10,5 
10,5 
10,5 
10,5 
SBC 
SBC 
SBC 
SBC 


R2,Rl 
IR2,Rl 
RI,IM 
IRI,IM 
f--- 
10,5 
10,5 
10,5 
10,5 
OR 
OR 
OR 
OR 
R2,RI 
IRZ,Rl 
Rl,IM 
IRl,IM 
f--- 
10,5 
10,5 
10,5 
10,5 
AND 
AND 
AND 
AND 
R2,Rl 
IRZ,Rl 
Rl,IM 
IRl,IM 
I---- 
10,5 
10,5 
10,5 
10,5 


TCM 
TCM 
TCM 
TCM 


Rz,Rl 
IRz,Rl 
Rl,IM 
IRI,IM 
I---- 
10,5 
10,5 
10,5 
10,5 


TM 
TM 
TM 
TM 


R2,RI 
IRz,RI 
Rl,IM 
IRI,IM 
I---- 


6,1 
DI 


I---- 


6,1 
EI 
- 
10,5 
10,5 
10,5 
10,5 
14,0 
CP 
CP 
CP 
CP 
RET 
Rz,RI 
IRz,Rl 
Rl,IM 
IRl,IM 
- 
10,5 
10,5 
10,5 
10,5 
16,0 
XOR 
XOR 
XOR 
XOR 
IRET 
Rz,Rl 
IRZ,Rl 
Rl,IM 
IRl,IM 
- 
10,5 
6,5 
LD 
RCF 
II, x, Rz 
- 
20,0 
20,0 
10,5 
6,5 
CALL· 
CALL 
LD 
SCF 
JRRI 
DA 
IZ, x, Rl 
- 
10,5 
10,5 
10,5 
10,5 
6,5 
LD 
LD 
LD 
LD 
CCF 
Rz,Rl 
IRz,Rl 
Rl,IM 
IRl,IM 
t--- 
10,5 
6,0 
LD 
!t 
, 
~ 
, 
NOP 
R2,IRl 


\.. 
" "- 
..I 
\.. 


Bytes per 
V' 
V" 
~--------~~~----------,# ~ 
~ 


Instruction 
2 
3 


Lower 
Opcode 
Nibble 


Execution t 
Pipeline 
Cycles 
Cycles 


Upper 


Mnemonic 
Opcode ~A 
Nibble 


First 
Second 


Operand 
Operand 


*2-byte instruction; fetch cycle appears as a 3-byte instruction 
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2 


Legend: 
R = 8-Bit Address 
r = 4-Blt Address 
HI or rl = Dst Address 
R2 or r2 = Src Address 


Sequence: 


3 


Opcode, First Operand, Second Operand 


Note: The blank areas are not defined. 


8085-002 


Absolute 
Maximum 
Ratings 


Standard 
Test 
Conditions 


DC 
Character- 
istics 


8085-0313, 0312 


Voltages on all pins 
with respect to GND .......... -0.3 V to + 7.0 V 
Operating Ambient 
Temperature ........ See Ordering Information 
Storage Temperature ........ -65°C to + 1·50 °C 


The characteristics below apply for the 
following standard test conditions, unless 
otherwise noted. All voltages are referenced to 
GND. Positive current flows into the reference 
pin. Standard conditions are as follows: 


+5V 


2.1K 


Stresses greater than those listed under Absolute Maxi- 
mum Ratings may cause permanent damage to the device. 
This is a stress rating only; operation of the device at any 
condition above those indicated in the operational sections 
of these specifications is not implied. Exposure to absolute 
maximum rating conditions for extended periods may affect 
device reliability. 


o +4.75 V ~ Vee ~ +5.25 V 
o GND = 0 V 
o O°C =:;; TA =:;; +70°C* 


'See Ordering Information section for package 
temperature range and product number. 


+5V 
+5V 


18K 


Uk 


74 LS04 
74 LS04 


+5V 


1.Sk 


CLI~CK --i.><>--..--D>O---.-.----1,~- XTAL2 


I t 
CL = 15pF MAX 


'--------.-- XTAL1 


I 
I 1 
CL = 15pF MAX 


Figure 14. Test Load I 
Figure 15. Test Load 2 
Figure 16. TTL External Clock Interface Circuit 
(Both the clock and Its complement are required) 


Symbol 
Parameter 
Min 
Max 
Unit 
Condition 


VeH 
Clock Input High Voltage 
3.8 
Vee 
V 
Driven by External Clock Generator 


VeL 
Clock Input Low Voltage 
-0.3 
0.8 
V 
Driven by External Clock Generator 


,VIH 
Input High Voltage 
2.0 
Vee 
V 


VIL 
Input Low Voltage 
-0.3 
0.8 
V 


VRH 
Reset Input High Voltage 
3.8 
Vee 
V 


VRL 
Reset Input Low Voltage 
-0.3 
0.8 
V 


, VOH 
Output High Voltage 
2.4 
V 
IoH = -250 /LA 


VOL 
Output Low Voltage 
0.4 
V 
IoL = +2.0 rnA 


IlL 
Input Leakage 
-10 
10 
/LA 
o V::5 VIN S +5.25 V 


IoL 
Output Leakage 
-10 
10 
/LA 
o V::5 VIN S +5.25 V 


IIR 
Reset Input Current 
-50 
/LA 
Vee' = +5.25 V, VRL = 0 V 


lec 
Vee Supply Current 
180 
rnA 


IMM 
VMM Supply Current 
10 
rnA 
Power Down Mode 


VMM 
Backup Supply Voltage 
3 
Vee 
V 
Power Down 
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· External I/O 
RlW 
or Memory 
Read and 
Write Timing 
PORT 0, 


DM 


PORT 1 


As 


os 


(READ) 


PORT 1 
Afl-AT 


58 
(WRITE) 


Figure 17. External I/O or Memory Read/Write 


No. 
Symbol 
Parameter 


1 
TdA(AS) 
Address Valid to AS t Delay 


2 
TdAS(A) 
AS t to Address Float Delay 


3 
TdAS(DR) 
AS t to Read Data Required Valid 


4 
TwAS 
AS Low Width 


, 5 
TdAz(DS) 
Address Float to DS I 
6-TwDSR 
DS (Read) Low Width 


7 
TwDSW 
DS (Write) Low Width 


8 
TdDSR(DR) 
DS I to Read Data Required Valid 
9 
ThDR(DS) 
Read Data to DS t Hold Time 


10 
TdDS(A) 
DS t to Address Active Delay 


11 
TdDS(AS) 
DS t to AS I Delay 


12 - 
TdRIW(AS) -- R/W Valid to AS t Delay 


13 
TdDS(R/W) 
DS I to RlW Not Valid 


14 
TdDW(DSW) 
Write Data Valid to DS (Write) I Delay 


15 
TdDS(DW) 
DS t to Write Data Not Valid Delay 


16 
TdA(DR) 
Address Valid to Read Data Required Valid 


17 
TdAS(DS) 
AS t to DS I Delay 


NOTES: 
1. Test Load 1 
2. Timing numbers given are for minimum TpC. 
3. Also see clock cycle time dependent characteristics table. 
4. When using extended memory timing add 2 TpC. 
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Z8601/3 
Z8601-12 
Min 
Max 
Min 
Max 
Notes*t 


50 
35 
1,2,3 


70 
45 
1,2,3 


360 
220 
1,2,3,4 


80 
55 
1,2,3· 


0 
0 
1 


250 
185 
·1,2,3,4 


160 
110 
1,2,3,4 


200 
130 
1,2,3,4 


0 
0 


70 
45 
1,2,3 


70 
55 
1,2,3 


50 
30 
1,2,3 


60 
35 
1,2,3 


50 
35 
1,2,3 


70 
45 
1,2,3 


410 
255 
1,2,3,4 


80 
55 
1,2,3 


5. All timing references use 2.0 V for a logic "1" and 0.8 V for a logic "0". 
* All units in nanoseconds (ns). 
t Timings are preliminary and subject to change. 


2194-011 


Additional 
Timing 
Table 


No. 
Symbol 


1 
TpC 


2 
TrC/TfC 


3 
TwC 
4 
TwTinL 
5-TwTinH 


6 
TpTin 


7 
TrTin, TfTin 


8a 
TwIL 


8b 
TwIL 


9 
TwIH 


NOTES: 


Parameter 


Input Clock Period 


Clock Input Rise And Fall Times 


Input Clock Width 


Timer Input Low Width 


Timer Input High Width 
Timer Input p'eriod 


Timer Input Rise And Fall Times 


Interrupt Request Input Low Time 


Interrupt Request Input Low Time 


Interrupt Request Input High Time 


1. Clock timing references uses 3.8 V for a logic" 1" and 0.8 V for 
a logic "0". 


2. Timing reference uses 2.0 V for a logic "1" and 0,8 V for 
a logic "0". 


Figure 18. Additional Timing 


Z860l!3 
Z8601-12 


Min 
Max 
Min 


125 
1000 
83 


25 


37 
26 


100 
70 


3TpC 
3TpC 


8TpC 
8TpC 


100 


100 
70 


3TpC 
3TpC 


3TpC 
3TpC 


3. Interrupt request via Port 3 (P31-P33)' 
4. Interrupt request via Port 3 (P30)' 
• Units in nanoseconds (ns). 


Max 


1000 


15 


100 


i Timings are preliminary and subject to change. 


Z8603 
Memory Port 
Timing 


Ao-A10 ~ 
_______________________________________ A_D_D_RE_S_S_VA_L_ID ________________________________________ ~t< 
_----..J_r.-. _CD ----Jj 
T~~ 


No. 
Symbol 


2 


NOTES: 


TdA(DI) 


ThDI(A) 


Do-D7 
DON'T CARE 
~ 
DATA IN VALID 
~ 


Figure 19. Memory Port Timing 


Parameter 


Address Valid to Data Input Delay 


Data In Hold Time 


Min 


a 


Z8601 


Max 


460 


Z8601 


Min 
Max 


320 


a 


Notes*t 


2 


2 


2 


2 


2/3 
2,4 


2/3 


Notes* 


1/2 


1. Test Load 2 
2. This is a Clock-Cycle-Dependent parameter. For clock frequen- 


cies other than the maximum, use the following formula: 


• Units are nanoseconds unless otherwise speCified; timings are 
preliminary and subject to change. 


28601/3 = 5 TpC - 
165 
' 


28601/3-12 = 5 TpC - 95 


2194-012 2037-019 
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lSI 
00 ! ... - 
W 
:I " 
c:I 


Handshake 
Timing 
DATA IN 


DAY 
(INPUT) 


ROY 
(OUTPUTI 


DATA OUT 


Figure 20a. Input Handshake 


x--- 
DATA OUT VALID 
-~----- 


)f-----(~®>-----I-~-E1!= 


No. 
Symbol 


DAY 


(OUTPUTI 


ROY 
(INPUTI 


Parameter 


1 
TsDI(DAV) 
Data In Setup Time 


2 
ThDI(DAV) 
Data In Hold Time 


3 
TwDAV 
Data Available Width 


Figure 20b. Output Handshake 


Z8601/3 
Z8601!3-12 


Min 
Max 
Min 
Max 


0 
0 
230 
160 


175 
120 


Notes*t 


4 
TdDAVIf(RDY) 
DAV I Input to RDY I Delay 
175 


5-TdDAVOf(RDY)-DAV I Output to RDY I Delay--------- 0 
0 


120 
1,2 
------1,3 


6 
TdDAVIr(RDY) 
DAV 1 Input to RDY 1 Delay 


TdDAVOrRDY) 
DAV 1 Output to RDY 1 Delay 


TdDO(DAV) 
Data Out to DAV I Delay 


7 
8 


9 
TdRDY(DAV) 
Rdy I Input to DAV 1 Delay 


NOTES: 
I. Test load I 
2 .. Input handshake 
3. Output handshake 
4. All timing regerences use 2.0 V for a logic "I" and 0.8 V for 
a logic "0". 


Clock- 
Cycle-Time- 
Number 
Symbol 
Dependent 
TdA(AS) 


Characteristics 
2 
TdAS(A) 


3 
TdAS(DR) 


4 
TwAS 


6 
TwDSR 


7 
TwDSW 


8 
TdDSR(DR) 


10 
Td(DS)A 


11 
TdDS(AS) 


12 
TdRlW(AS) 


13 
TdDS(RIW) 


14 
TdDW(DSW) 


15 
TdDS(DW) 


16 
TdA(DR) 


17 
TdAS(DS) 


• Add 2TpC when using extended memory timing 
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175 
120 


0 
0 


50 
30 


0 
200 
0 
140 


• Units in nanoseconds (ns). 
t Timings are preliminary and subject to change. 


Z8601!3 
Z8601!3-12 


Equation 
Equation 


TpC-75 
TpC-50 


TpC-55 
TpC-40 


4TpC-140* 
4TpC-llO* 


TpC-45 
TpC-30 


3TpC-125* 
3TpC-65* 


2TpC-90* 
2TpC-55* 


3TpC-175* 
3TpC-120* 


TpC-55 
TpC-40 


TpC-55 
TpC-30 


TpC-75 
TpC-55 


TpC-65 
TpC-50 


TpC-75 
TpC-50 


TpC-55 
TpC-40 


5TpC-215* 
5TpC-160* 


TpC-45 
TpC-30 


1,2 


1,3 


1 


2194·013 


Ordering 
Product 
Package/ 
Product 
Package/ 
Information 
Number 
Temp 
Speed 
Description 
Number 
Temp 


28601 
CE 
8.0 MHz 
28MCU 
28601-12 
PE 


(2K ROM, 40-pin) 


28601 
CS 
8.0 MHz 
Same as above 
28601-12 
PS 


28601 
PE 
8.0 MHz 
Same as above 
28603 
RS 


28601 
PS 
8.0 MHz 
Same as above 


28601-12 
CE 
12.0 MHz 
ZSMCU 
(2K ROM,40-pin) 
28603-12 
RS 
28601-12 
CS 
12.0 MHz 
Same as above 


NOTES: C = Ceramic, P = Plastic, R = Protopack; E = 40° to 85°C, S = O°C to +70°C. 


Speed 


12.0 MHz 


12.0 MHz 


8.0 MHz 


12.0 MHz 


Description 


28MCU 
(2K ROM, 40-pin) 


Same as above 


ZSMCU 
(2K XROM, 
Prototyping Device, 
40-pin) 


Same as above 
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II ! ... - 
W • 
n 
c:I 


Zilog 


Features 


General 
Description 


2038·001, 002 


II Complete microcomputer, 4K bytes of ROM, 


128 bytes of RAM, 32 I/O lines, and up to 
60K bytes addressable external space each 
for program and data memory. 


III 144-byte register file, including 124 
general-purpose registers, four I/O port 
registers, and 16 status and control 
registers. 


rI Average instruction execution time of 
1.5 fJ-S, maximum of 3 fJ-S. 
a Vectored, priority interrupts for I/O, 


counter/timers, and UART. 


The Z8611 microcomputer introduces a new 
level of sophistication to single-chip architec- 
ture. Compared to earlier single-chip micro- 
computers, the Z8611 offers faster execution; 
more efficient use of memory; more sophisti-' 
cated interrupt, input/output and bit-manipula- 
tion capabilities; and easier system expansion. 


Under program control, the Z8611 can be 
tailored to the needs of its user. It can be con- 


PORTO 
(NIBBLE 


PROGRAMMABLE) 


1/0 OR As-A" 


PORT 1 
(BYTE 


PROGRAMMABLE) 
1/0 OR ADD-AD, 


PORT 2 
(BIT PRO· 
GRAMMABLE) 
1/0 


PORT 3 
(FOUR INPUT; 
FOUR OUTPUT) 
SERIAL AND 
PARALLEL 1/0 
AND CONTROL 


Figure 1. Z8BU MCU Pin Functions 


I 
Z8® Family of 
Microcomputers 
Z8611 CD Z8612 • Z8613 


Product 
Specification 


September 1983 


28611 Single-Chip Microcomputer with 4K ROM 
28612 Development Device with Memory Interface 
28613 Prototyping Device with EPROM Interface 


II Full-duplex UART and two programmable 
8-bit counter/tirpers, each with a 6-bit 
programmable prescaler. 


a Register Pointer so that short, fast instruc- 
tions can access any of nine working- 
register groups in 1 fJ-S. 


IJ On-chip oscillator which accepts crystal or 
external clock drive. 


Ii1 Low-power standby option that retains con- 


tents of general-purpose registers. 


Ii Single + 5 V power supply-all pins TTL- 
compatible. 


figured as a stand-alone microcomputer with 
4K bytes of internal ROM, a traditional micro- 
processor that manages up to 120K bytes of 
external memory, or a parallel-processing ele- 
ment in a system with other processors and 
peripheral controllers linked by the Z-BUS. In 
all configurations, a large number of pins 
remain available for I/O. 


+5V 
P3. 


XTAL2 
P3, 


XTALl 
P27 
P3, 
P2. 


P3, 
P2. 


REID 
P2. 
R/W 
P23 
os 
P2. 
AS 
P2, 
P3. 
P2, 


GND 
P33 


P3. 
P3. 


po, 
Pl, 


po, 
Pl. 
po. 
Pl. 
P03 
Pl. 


po. 
P1 3 
po. 
Pl. 


po. 
Pl, 


po, 
Pl 0 


Figure 2. Z8BU MCU Pin Assignments 
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Architecture 
28611 architecture is characterized by a 
microprocessor that can address 120K bytes of 
external memory (Figure 3). 


Pin 
Description 


506 


flexible I/O scheme, an efficient register and 
address space structure and a number of 
ancillary features that are helpful in many 
applications. 
Microcomputer applications demand power- 
ful I/O capabilities. The 28611 fulfills this with 
32 pins dedicated to input and output. These 
lines are grouped into four ports of eight lines 
each and are configurable under software con- 
trol to provide timing, status signals, serial or 
parallel I/O with or without handshake, and an 
address/data bus for interfacing external 
memory. 
Because the multiplexed address/data bus is 
merged with the I/O-oriented ports, the 28611 
can assume many different memory and I/O 
configurations. These configurations range 
from a self-contained microcomputer to a 


OUTPUT 
Vee 'GND 
! ! 


FLAGS 


Three basic address spaces are available to 
support this wide range of configurations: pro- 
gram memory (internal and external), data 
memory (external) and the register file (inter- 
nal). The 144-byte random-access register file 
is composed of 124 general-purpose registers, 
four I/O port registers, and 16 control and 
status registers. 
To unburden the program from coping with 
real-time problems such as serial data com- 
munication and counting/timing, an asynchro- 
nous receiver/transmitter (UART) and two 
counter/timers with a large number of user- 
selectable modes are offered on-chip. Hard- 
ware support for the UART is minimized 
because qne of the on-chip timers supplies the 
bit rate. 


REG. POINTER 


I/O 
(BIT PROGRAMMABLE) 


ADDRESS OR 110 
(NIBBLE PROGRAMMABLE) 


ADDRESSIDATA OR 110 


(BYTE PROGRAMMABLE) 


Figure 3. Functional Block Diagram 


AS. Address Strobe (output, active Low). 
Address Strobe is pulsed once at the begin- 
ning of each machine cycle. Addresses output 
via Port 1 for all external program or data 
memory transfers are valid 'at the trailing edge 
of AS. Under program control, AS can be 
placed in the high-impedance state along with 
Ports 0 and 1, Data Strobe and Read/Write. 
OS. Data Strobe (output, active Low). Data 
Strobe is ~ctivated once for each external 
memory transfer. 


POO-P01' P1o-P11. P20-P21' P30-P31. I/O Port 
Lines (input/outputs, TTL-compatible). These 
32 lines are divided into four 8-bit I/O ports 
that can be configured under program control 


for I/O or external memory interface. 


RESET. Reset (input, active Low). RESET ini- 
tializes the 28611. When RESET is deactivated, 
program execution begins from internal pro- 
gram location,OOOCH. 


R/W. Read/Write (output). R/W is Low when 
the 28611 is writing to external pr'ogram or 
data memory. 
XTALI. XTAL2. Crystall, Crystal 2 (time-base 
input and output). These pins connect a 
parallel-resonant crystal (8 or 12 MHz max- 
imum) or an externalsingle-phase clock (8 or 
12 MHz maximum) to the on-chip clock 
oscillator and buffer. 


2037-003 


Address 
Spaces 
Program Memory. The 16-bit program 
counter addresses 64K bytes of program 
memory space. Program memory can be 
located in two areas: one internal and the 
other external (Figure 4). The first 4096 bytes 
consist of on-chip mask-programmed ROM. At 
addresses 4096 and greater, the Z8611 
executes external program memory fetches. 
The first 12 bytes of program memory are 
reserved for the interrupt vectors. These loca- 
tions contain six 16-bit vectors that correspond 
to the six available interrupts. 
Data Memory. The Z8611 can address 60K 
bytes of external data memory beginning at 


Location 0 
first byte 0 
Instruction 


I 
I 


5535 


4096 
4095 


EXTERNAL 


ROM OR RAM 


ON·CHIP 
ROM 


!~ 


executed 
efterrese 
~------------ 


I 
Interrup 


Vecta 


(Lower Byte ; 


I 
Interrup 


Vectc 


(Upper Byte 
r 
) 


11 
IR05 


10 
IR05 


9 
IR04 


8 
IR04 


7 
IR03 


6 
IR03 
5"'- 
IR02 


4j..- 
IR02 


3 
IROI 


2 
IROI 


1 
IROO 


0 
IROO 


Figure ,4. Program Memory Map 


LOCATION 


255 
254 
253 


252 


251 
250 
249 


248 


247 


248 


245 
244 


243 
242 


241 
240 


127 


STACK POINTER (BITS 7-0) 


STACK POINTER (BITS 15-8) 


REGISTER POINTER 


PROGRAM CONTROL FLAGS 


INTERRUPT MASK REGISTER 


INTERRUPT REQUEST REGISTER 


INTERRUPT PRIORITY REGISTER 


PORTS 0-1 MODE 


PORT 3 MODE 


PORT 2 MODE 


TO PRESCALER 


TIMER/COUNTER 0 


Tl PRESCALER 


TIMER/COUNTER 1 


TIMER MODE 


SERIAL I/O 


NOT 
IMPLEMENTED 


GENERAL·PURPOSE 
REGISTERS 


PORT 3 


PORT 2 


PORT 1 


PORT 0 


Figure 6. The Register File 


IDENTIFIERS 


SPL 


SPH 


RP 


FLAGS 


IMR 


IRQ 


IPR 


POIM 


P3M 


P2M 


PREO 


TO 


PREI 


T1 


TMR 


SIO 


P3 


P2 


PI 


PO 


2038·004, 005 2037·006. 007 


location 4096 (Figure 5). External data memory 
may be included with or sepa.rated from the 
external program memory space. 
DM, an optional I/O function that can be 
programmed to appear on pin P34, is used 
to distinguish between data and program 
memory space. 
Register File. The 144-byte register file 
includes four I/O port registers (RO-R3), 124 
general-purpose registers (R4-RI27) and 16 
control and status registers (R240-R255). These 
registers are assigned the address locations 
shown in Figure .6. 


Z8611 instructions can access registers 


65535 _---------""1 


EXTERNAL 
DATA 


MEMORY 


:~~~ ~----------I 


NOT ADDRESSABLE 


Figure 5. Data 'Memory Map 


r-_ 
~---;-;:{ ~----.255 
~ 1--~"':-;;"""';_..L..-____ 
-I253 
1----------..1240 


The upper nibble of the register file address 
provided by the register poinler specifies 
the active working·reglster group. 


SPECIFIED WORKING, 
REGISTER GROUP 


1 27 


'-1- 


1 


The lower 
nibble of 
the register 
til. address 
provided by 
the Instruction 
pOints to the 
specified 
register. 


1--------------3 
110 PORTS 


Figure 7. The Regist~r Pointer 
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Address 
Spaces 
(Continued) 


Serial 
Input/ 
Output 


Counter/ 
Timers 
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directly or indirectly with an 8-bit address 
field. The Z8611 also allows short 4-bit register 
addressing using the Register Pointer (one of 
the control registers). In the 4-bit mode, the 
register file is divided into nine working- 
register groups, each occupying 16 contiguous 
locations (Figure 7). The Register Pointer 
addresses the starting location of the active 
working-register group. 


Port 3 lines P30 and P37 can be programmed 
as serial I/O lines for full-duplex serial asyn~ 
chronous receiver/transmitter operation. The 
bit rate is controlled by Counter/Timer 0, with 
a maximum rate of 62.5K bits/second for 8 
MHz and 94.8K bits/second for 12 MHz. 
The Z8611 automatically adds a start bit and 
two stop bits to transmitted data (Figure 8). 
Odd parity is also available as an option. Eight 
data bits are always transmitted, regardless of 


Transmitted Data 
(No Parity) 


LSTART BIT 
'------EIGHT DATA BITS 


Transmitted Data 
(With Parity) 


I 
SP I SP 1 P I 0.1 051 0.1 031 0,1 0, 1 
Do 1 
sTI 


TWO STOP BITS 


T L 


_LsTARTBIT 
'------SEVEN DATA BITS 


ODD PARITY 


TWO STOP BITS 


Stacks. Either the internal register file or the 
external data memory can be used for the 
stack. A 16-bit Stack Pointer (R254 and R255) 
is used for the external stack, which can reside 
anywhere in data memory between locations 
4096 and 65535. An 8-bit Stack Pointer (R255) 
is used for the internal stack that resides within 
the 124 general-purpose registers (R4-RI27). 


parity selection. If parity is enabled, the eighth 
bit'is the odd parity bit. An interrupt request 
(IRQ4) is generated on all transmitted 
characters. 
Received data must have a start bit, eight 
data bits and at least one stop bit. If parity is 
on, bit 7 of the received data is replaced by a 
parity error flag. Received characters generate 
the IRQ3 interrupt request. 


Received Data 
(No Parity) 


I SP I 0, I 0.1 051 0.1 031 0,1 0, I Do I ST I 


I 


LSTART BIT 
L..-----EIGHT DATA BITS 
L..---------ONE STOP BIT 


Received Data 
(With Parity) 


IDlpl~I~I~I~I~I~I~I~1 
II 


LSTART BIT 
'-_____ 
-'--__ SEVEN DATA BITS 
- 
PARITY ERROR FLAG 


'----------ONE STOP BIT 


Figure 8. Serial Data Formats 


The Z8611 contains two 8-bit programmable 
counter/timers (To and TIL each driven by its 
own 6-bit programmable prescaler. The TI 
prescaler can be driven by internal or external 
clock sources; however, the To prescaler is 
driven by the internal clock only. 
The 6-bit prescalers can divide the input fre- 
quency of the clock source by any number 
from 1 to 64. Each prescaler drives its counter, 
which decrements the value (1 to 256) that has 
been loaded into the counter. When the 
counter reaches the end of count, a timer 
interrupt request-IRQ4 (To) or IRQ5 (TI)- 
is generated. 
The counters can be started, stopped, 
restarted to continue, or restarted from the 
initial value. The counters can also be pro- 
grammed to stop upon reaching zero (single- 
pass mode) or to automatically reload the 


initial value and continue counting (modulo-n 
continuous mode). The counters, but not the 
prescalers, can be read any time without 
disturbing their value or count mode. 
The clock source for T I is user-definable and 
can be the internal microprocessor clock 
(4 MHz maximum for the 8 MHz device and a 
6 MHz maximum fd'r the 12 MHz device.) 
divided by four, or an external signal input via 
Port 3. The Timer Mode register configures the 
external timer input as an external clock 
(1 MHz maximum), a trigger input that can be 
retriggerable or non-retriggerable, or as a - 
gate input for the internal clock. The 
counter/timers can be programmably cascaded 
by connecting the To output to the input of TI. 
Port 3 lineP36 also serves as a timer output 
(TOUT) through which To, T I or the internal 
clock can be output. 


2047-009 


I/O Ports 


2037-008 


The 28611 has 32 lines dedicated to input 
and output. These lines are grouped into four 
ports of eight lines each and are configurable 
as input, output or address/data. Under soft- 
ware control, the ports can be programmed to 


Port 1 can be programmed as a byte I/O 


port or as an address/data port for interfacing 
external memory. When used as an I/O port, 
Port 1 may be placed under handshake con- 
trol. In this configuration, Port 3 lines P33 and 
P34 are used as the handshake controls RDY 1 
and DAVl (Ready and Data Available). 
Memory locations greater than 4096 are 
referenced through Port 1. To interface exter- 
nal memory, Port 1 must be programmed 
for the multiplexed Address/Data mode. If 
more than 256 external locations are required, 
Port a must output the additional lines., 
Port 1 can be placed in the high-impedance 
state along with Port 0, AS, DS and R/W, 


Port 0 can be programmed as a nibble I/O 


port, or as an address port for interfacing 
external memory. When used as an I/O port, 
Port a may be placed under handshake con- 
trol. In this configuration, Port 3 lines P32 and 
P3s are used as the handshake controls DA Vo 
and RDYo. Handshake signal assignment is 
dictated by the I/O direction of the upper 
nibble P04 - P07. ' 
For external memory references, Port a can 
provide address bits Aa-All (lower nibble) or 
As-AlS (lower and upper nibble) depending 
on the required address space. If the address 
range requires 12 bits or less, the upper nibble 
of Port a can be programmed independently as 


Port 2 bits can be programmed inde- 
pendently as input or output. This port is 
always available for I/O operations. In addi- 
tion, Port 2 can be configured to provide 
open-drain outputs. 
Like Ports a and I, Port 2 may also be 
placed under handshake control. In this con- 
figuration, Port 3 lines P3l and P36 are used as 
the handshake controls lines DAV2and RDY2. 
The handshake signal assignment for Port 3 
lines P3l and P36 is dictated by the direction 
(input or output) assigned to bit 7 of Port 2. 


Port 3 lines can be configured as I/O or con- 
trollines. In either case, the direction of the 
eight lines is fixed as four input (P30-P33) and 
. four output (P34-P37)' For serial I/O, lines P30 
and P37 are programmed as serial in and serial 
out respectively. 


Port 3 can also provide the follOWing control 
functions: handshake for Ports a, 1 and 2 
(DAV and RDY); four external interrupt 
request signals (IRQO-IRQ3); timer input and 
output signals (TIN and TOUT) and Data 
Memory Select (DM). 


provide address outputs, timing, status signals, 
serial I/O, and parallel I/O with or without 
handshake. All ports have active pull-ups and 
pull-downs compatible with TTL loads. 


allowing the 28611 to share common resources 
in multiprocessor and DMA applications. Data 
transfers can be controlled by assigning P33 as 
a Bus Acknowledge input, and P34 as a Bus 
Request output. 


PORT 1 
(1/0 OR ADo-AD,) 


} 
HANDSHAKE CONTROLS 
DAV, AND RDY, 
(P33 AND P3.) 


Figure 9a. Port 1 


I/O while the lower nibble is used for address- 
ing. When Port a nibbles are defined as 
address bits, they can.be set to the high- 
impedance state along with Port 1 and the con- 
trol signals AS, DS and R/W. 


} 
PORT 0 
(1/0 OR As-A,.> 


_ 
} HANDSHAKE CONTROLS 
DAVo AND RDYo 
(P3. AND P3S> 


Figure 9b. Port 0 


PORT 2(1/0) 


} 
HANDSHAKE CONTROLS 
DAV. AND RDY2 
(P3, AN D P3s) 


Figure 9c. Port 2 


PORT 3 
(1/0 OR CONTROL) 


Figure 9d. Port 3 
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The ·Z8611 allows six different interrupts from 
eight sources: the four Port 3 lines P30-P33, 
Serial In, Serial Out, and the two counterl 
timers. These interrupts are both maskable and 
prioritized. The Interrupt Mask register glob- 
ally or individually enables or disables the six 
interrupt requests. When more than one inter- 
rupt is pending, priorities are resolved by a 
programmable priority encoder that is con- 
trolled by the Interrupt Priority register. 
. All Z8611 interrupts are vectored. When an 
interrupt request is granted, an interrupt 
. machine cycle is entered. This disables all 


The on-chip oscillator has a high-gain, 
parallel-resonant amplifier for connection to a 
crystal or to any suitable external clock source 
(XTALI = Input, XTAL2 = Output). 
The crystal source is connected across 
XTALI and XTAL2, using the recommended 
capacitors (Cl ~ 15 pF) from each pin to 


The low-power standby mode allows power 
to be removed without losing the contents of 
the 124 general-purpose registers. This mode 
is available to the user as a bonding option 
whereby pin 2 (normally XTAL2) is replaced 
by the VMM (standby) power supply input. This 
necessitates the use of an external clock 
generator (input = XTALl) rather than a 
crystal source. 
The removal of power, whether intended or 
due to power failure, must be preceded by a 
software routine that stores the appropriate 
status into the register file. Figure 10 shows 


This 64-pin development version of the 
40-pin mask-programmed Z8611 (Figure 11) 
allows the user to prototype the system in hard- 
ware with an actual device and to develop the 
code that is eventually mask-programmed into 
the on-chip ROM of the Z861l. 


The Z8612 is identical to the Z8611 with the 


. following exceptions: 
• The internal ROM has been removed. 


II The ROM address. lines and data lines are 
buffered and brought out to external pins. 


• Control lines for the new memory have 
been added. 


Pin Description. The functions of· the Z8612 
1/0 lines, AS, DS-, R/W, XTALl, XTAL2 and 
RESET are identical to those of their Z8611 
counterparts. The functions of the remaining 
24 pins are as follows: 
Ao-Au. Program Memory Address (outputs). 
Ao-All access the first 4K bytes of program 
memory. 


subsequent interrU:pts, saves the Program 
Counter and status flags, and branches to the 
program memory vector location reserved for 
that interrupt. This memory location and the 
next byte contain the 16-bit address of the 
'interrupt service routine for that particular 
interrupt request. 


Polled interrupt systems are also supported. 
To accommodate a polled structure, any or all 
of the interrupt inputs can be masked and the 
Interrupt Request register polled to determine 
which of the interrupt requests needs service . 


ground. The specifications for the crystal are 
as follows: 


• AT cut, parallel resonant 
.. Fundamental type, 8/12 MHz maximum 
II Series resistance, Rs ~ 100 n 


the recommended circuit for a battery back-up 
supply system. 


+5 V O----~~-__1 
Voo 


Z8611 


J 


Figure 10. Recommended Driver Circuit 
for Power Down Operation 


P2s 
Vee 


P31 
XTAL2 


P27 
XTALl 


P2s 
P37 


P2s 
P30 


P24 
R~$ET 


P23 
RIW 


P22 
OS 


P21 
AS 


P20 
P3s 


P33 
P33 


P34 
poo 


P17 
POl 


PIs 
P02 


PIs 
P03 


P14 
P04 


P13 
GND 


P12 
POs 


P11 
POs 


P10 
P07 


07 
lACK 


Ds 
SYNC 


Ds 
SCLK 


04 
MOS 


Ao 
Do 


Al 
01 


A2 
D2 


A3 
D3 


A4 
All 


As 
Al0 


As 
As 


A7 
As 


Figure 11. Z8612 Pin Assignments 


2038-010, 011 


Z8612 
Do-D,. Program Data (inputs). Program data 
Development from the first 4K bytes of program memory is 
Device 
input through pins Do-D7. 
(Continued) 


Z8613 
Protopaclc 
Emulator 


lACK. Interrupt Acknowledge (output, active 
High). lACK is driven High in response to an 
interrupt during the interrupt machine cycle. 
MOS. Program Memory Data Strobe (output, 
active Low). MDS is Low during an instruction 
fetch cycle when the first 4K bytes of program 
memory are being accessed. 


The 28613 MPE (Protopack) is used for 
prototype development and preproduction of 
mask-programmed applications. The Protopack 
is a ROMless version of the standard 28611, 
housed in a pin-compatible 40-pin package 
(Figure 12). 
To provide pin compatibility and inter- 
changeability with the standard mask- 
programmed device, the Protopack carries 
(piggy-back) a 24-pin socket for a direct inter- 
face to program memory (Figure 1). The 
24-pin socket is equipped with 12 ROM 


SCLK. System Clock (output). SCLK is the 
internal clock output through a buffer. The 
clock rate is equal to one-half the crystal 
frequency. 
SYNC. Instruction Sync (output, active Low). 
This strobe output is forced Low during the 
internal clock period preceding an opcode 
fetch. 


address lines, 8 ROM data lines and necessary 
control lines for interface to 2732 EPROM for 
the first 4K bytes of program memory. 


Pin compatibility allows the user to 
design the pc board for a final 40-pin mask- 
programmed 28611, and, at the same time, 
allows the use of the Protopack to build the 
prototype and pilot production units. When the 
final program is established, the user can then 
switch over to the 40-pin mask-programmed 
28611 for large volume production. The Proto- 
pack is also useful in small volume applica- 
tions where masked ROM setup time, mask 
charges, etc., are prohibitive and program 
flexibility is desired. 
Compared to the conventional EPROM 


versions of the Single-chip microcomputers, 
the Protopack approach offers two main 
advantages: 


(J Ease of developing various programs during 
the prototyping stage: For instance, in 
applications where the same hardware 
configuration is used with more than one 
program, the 28613 Protopack allows 
economical program storage in separate 
EPROMs (or PROMs), whereas the use of 
separate EPROM-based Single-chip 
microcomputers is more costly. 


c Elimination of long lead time in procuring 
Figure 12. Tho Z6613 Microcomputer Protopack Emulator 
EPROM-based microcomputers. 


Instruction 
Set 
Notation 


Addressing Modes. The follOWing notation is used 
to describe the addressing modes and instruction 
operations as shown in the instruction summary. 


IRR 


Irr 
X 
DA 
RA 
1M 
R 


IR 


Ir 
RR 


Indirect register pair or indirect working-register 
pair address 
Indirect working-register pair only 
Indexed address 
Direct address 
Relative address 
Immediate 
Register or working-register address 
Working-register address only 
Indirect-register or indirect working-register 
address 
Indirect working-register address only 
Register pair or working register pair address 


Symbols. The follOWing symbols are used in 
describing the instruction set. 
dst 
Destination location or contents 
src 
Source location or contents 
cc 
Condition code (see list) 


@ 
Indirect address prefix 


SP 
Stack pointer (control registers 254-255) 
PC 
Program counter 


FLAGS 
Flag register (control register 252) 
RP 
Register pointer (control register 253) 
IMR 
Interrupt mask register (control register 251) 


Assignment of a value is indicated by the symbol 
\1-". For example, 
dst - dst + src 
indicates that the source data is added to the 
destination data and the result is stored in the 
destination location. The notation \laddr(n}" is used 
to refer to bit \In" of a given location. For example, 
dst (7) 
refers to bit 7 of the destination operand. 
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(Continued) 


Condition 
Codes 
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512 


Flags. Control Register R252 contains the following 
six flags: 
Affected flags are indicated by: 
o 
Cleared to zero 
C 
Carry flag 
Z 
Zero flag 


S 
Sign flag 


V 
Overflow flag 
D 
Decimal-adjust flag 
H 
Half-carry flag 


Value 
Mnemonic 


1000 
0111 
C 
1111 
NC 


0110 
Z 
1110 
NZ 
1101 
PL 
0101 
MI 


0100 
OV 
1100 
NOV 
0110 
EO 
1110 
NE 


1001 
GE 


0001 
LT 


1010 
GT 


0010 
LE 
1111 
UGE 


a III 
ULT 
1011 
UGT 
0011 
ULE 
0000 


dst 


1 
Set to one 


* 
Set or cleared according to operation 
Unaffected 
X 
Undefined 


Meaning 


Always true 
Carry 
No carry 
Zero 
Not zero 
Plus 
Minus 
Overflow 
No overflow 
Equal 
Not equal 
Greater than or equal 
Less than 
Greater than 
Less than or equal 
Unsigned greater than or equal 
Unsigned. less than 
Unsigned greater than 
Unsigned less than or equal 
Never true 


OPC 


OPC 


CCF, DI, EI, IRET, NOP, 
RCF, RET, SCF 


INCr 


One-Byte Instructions 


C 
1 
C = a 
Z = 1 
Z =0 
S = a 
S = 1 
V = 1 
V = a 
Z = 1 
Z = a 


Flags Set 


(S XOR V) = a 
(S XOR V) = 1 
[Z OR (S XOR V)] 
a 


[Z OR (S XOR V)] 
1 


C=O 
C = 1 
(C = a AND Z = 0) 
(C OR Z) = 1 


CLR, CPL, DA, DEC, 


L-""::":'=_-' OR h 1 1 01 dsllsrc 1 ~~~~'~~~Rt~~:R."OP, 


ADC, ADD, AND, CP, 
LD, OR, SBC, SUB, 
TCM, TM, XOR 


OPC 
I 
t---"d'--'st"----I OR 11 1 1 01 
dst 


OPC 
VALUE 


L..-....:.:..:=_.J. OR 11 1 1 01 


dst 
1 OPC 
VALUE 
I 
dsllCC R~ OPC 


RRC, SRA, SWAP 


JP, CALL (Indirect) 


SRP 


LD, LDE, LDEI, 
LDC, LDCI 


LD 


LD 


DJNZ, JR 


Two-Byte Instructions 


1-_"::::":'_--1 OR 111101 
dst 


ADC, ADD, AND, CP, 
LD, OR, SBC, SUB, 
TCM, TM, XOR 


LD 


LD 


JP 


CALL 


Three-Byte Instructions 
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Instruction 
Instruction 
Addr Mode 
Opcode Flags Affected 
Instruction 
Addr Mode 
Opcode Flags Affected 
Summary 
and Oporation 
dst 
Byte 
and Operation 
dst 
By to 
src 
(Hox) 
CZSVDH 
src 
(Hex) 
CZSVDH 


ADC dst,src 
(Note 1) 
10 
* 0 * 
LDE dst,src 
r 
Irr 
82 
------ 
dst - dst + src + C 
dst - 
src 
Irr 
92 


ADD dst,src 
(Note 1) 
00 
* 0 * 
LDEI dst,src 
Ir 
Irr 
83 
------ 
dst - 
dst + src 
dst - 
src 
Irr 
Ir 
93 


AND dst,src 
(Note 1) 
50 
0 
r - r + 1; rr-rr+l 
- 
* * 
dst - 
dst AND src 
NOP 
FF 
------ 


CALL dst 
DA 
D6 
------ 
OR dst,src 
(Note 1) 
40 
0-- 
SP - 
SP - 2 
IRR 
D4 
dst - dst OR src 


@SP - PC; PC - dst 
POP dst 
R 
50 
------ 


CCF 
EF 
* - - - - - 
dst - 
@SP 
IR 
51 


C - 
NOT C 
SP - 
SP + 1 


CLR dst 
R 
BO 
------ 
PUSH src 
R 
70 


dst - 
0 
IR 
Bl 
SP - SP-l; @SP - src 
IR 
71 


COM dst 
R 
60 
- 
* * 0 
RCF 
CF 
o - - - - - 
dst - 
NOT dst 
IR 
61 
C-O 


CP dst,src 
(Note 1) 
AD 
RET 
AF 
------ 
a 
dst - src 
PC - @ SP; SP - SP + 2 


DA dst 
R 
40 
* * * x - - 
RL dst 
~I~ 
90 
G) 


dst - 
DA dst 
IR 
41 
91 
... 
.... - 
DEC dst 
R 
00 
-***-- 
RLC dst ~, '~I~ 
10 
£WI 


dst - 
dst - 1 
IR 
01 
11 
N - 
RR dst L[ri L{6)J I~ 
EO 
* * - - 
Id 
DECW dst 
RR 
80 
-***-- 
El 
W 


dst - 
dst - 1 
IR 
81 
~ 
RRC· dst LE1=ciJ R 
CO 
* * 'Ii 
n 
DI 
c 
, 
, 
IR 
Cl 
~ 
IMR (7) - 
0 
8F 
------ 
SBC dst,src 
(Note 1) 
3D 
* * 1 * 


DJNZ r,dst 
RA 
rA 
------ 
dst - dst - src - C 


r - 
r - 1 
r=O-F 
SCF 
DF 
1 - 
- - 
if r * 0 
C-l 
PC - 
PC + dst 
SRA dst ~ ru ,rJ I~ 
DO 
Range: + 127, -128 
* * * 0 


Dl 
EI 
9F 
------ 
SRP src 
1m 
31 
IMR (7) - 
1 
RP - 
src 


INC dst 
rE 
-***-- 
SUB dst,src 
(Note 1) 
20 
* * 1 * 
dst - 
dst + 1 
r=O-F 
dst - dst - src 
R 
20 


IR 
21 
SWAPdstr@ R 
FO 
X * * X - - 


INCW dst 
AO 
IR 
Fl 
RR 
-***-- 
dst - 
dst + 
IR 
Al 
TCM dst,src 
(Note 1) 
60 
- 
* * 0 - - 


IRET 
BF 
(NOT dst) AND src 


FLAGS - 
@SP; SP - SP + 1 
TM dst, src 
(Note 1) 
70 
- 
* * 0 
PC - 
@SP; SP - SP +2; IMR(7) - 
1 
dst AND src 


JP cc,dst 
DA 
cD 
------ 
XOR dst,src 
(Note 1) 
BO 
-**0-- 
if cc is true 
c=O-F 
dst - dst XOR src 


PC - 
dst 
IRR 
30 


JR cc,dst 
RA 
cB 
------ 
Note 1 
if cc is true, 
c=O-F 


PC - PC + dst 
These instructions have an identical set of addressing 
Range: + 127, -128 
modes, which are encoded for brev:ity. The first opcode 
nibble is found in the instruction set table above. The 
LD dst,src 
1m 
rC 
------ 
second nibble is expressed symbolically by a D in this 
dst - 
src 
r 
R 
r8 
table, and its value is found in the following table to the 
R 
r9 
left of the applicable addressing mode pair. 
r=O-F 
For example, to determine the opcode of an ADC 
r 
X 
C7 
instruction use the addressing modes r (destination) and 
X 
r 
D7 
Ir (source). The result is 13. 
r 
Ir 
E3 
Ir 
r 
F3 
R 
R 
E4 
AddrMode 
R 
IR 
E5 
Lower 
R 
1m 
E6 
dst 
src 
Opcode Nibble 
IR 
1m 
E7 
IR 
R 
F5 
[l) 


LDC dst,src 
r 
Irr 
C2 
------ 
Ir 
rn 


dst - 
src 
Irr 
D2 
R 
R 
[!l 
LDCI dst,src 
Ir 
Irr 
C3 
------ 
R 
IR 
lID 


dst - 
src 
Irr 
Ir 
D3 
R 
1M 
@] 
r - r + 1; rr - rr + 1 
IR 
1M 
(2) 
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Registers 
R240 SIO 
Serial I/O Register 
(FOH; Read/Write) 


'------ SERIAL DATA (Do = LSB) 


R241 TMR 
Timer Mode Register 
(FIH; Read/Write) 
I 0,1 0,1 Os I 0,1 031 0,1 0, I 
Do I 


NOT USED = 00 .-J 
1 = LOAD To 
TOUT MODES J 
lS~O 
= NO FUNCTION 


~: g~~ ~ ~~ 
0 = DISABLE To COUNT 
INTERNAL CLOCK. OUT = 11 
1 = ENABLE To COUNT 


T 
MODES 
0 = NO FUNCTION 


EXTERNAL CLOCK IN~~T = 00 
1 = LOAD T, 
GATE INPUT = 01 
0 = DISABLE T, COUNT 
TRIGGER INPUT = 10 
1 = ENABLE T, COUNT 
(NON·RETRIGGERABLE) 
TRIGGER INPUT = 11 


(RETRIGGERABLE) 


R242 Tl 
Counter Timer 1 Register 
(F2H; Read/Write) 
I 0,\ 0.\ Os \ 0.\ 03 \ 0,\ 0, \ 
Do I 


T, INITIAL VALUE (WHEN WRITTEN) 
'------(RANGE 1-256 DECIMAL 01-00 HEX) 


T, CURRENT VALUE (WHEN READ) 


R243 PREI 
Prescaler 1 Register 
(F3H; Write Only) 


I~I~I~I~I~I~I~I~I 


~ 


COO~N;, ~~G~E'PA.SS 
1 = T, MODULO·N 


CLOCK SOURCE 


1 = T, INTERNAL 
o = T, EXTERNAL TIMING INPUT 


(T,N) MODE 


PRESCALER MODULO 
L...------(RANGE: 1-64 DECIMAL 
01-00 HEX) 


R244 TO 


Counter/Timer 0 Register 
(F4H; Read/Write) 


To INITIAL VALUE (WHEN WRITTEN) 
'------(RANGE: 1-256 DECIMAL 01-00 HEX) 
To CURRENT VALUE (WHEN READ) 


R245 PREO 
Prescaler 0 Register 
(F5H; Write Only) 


I~I~I~I~I~I~I~I~I 
~L 


COUNT MODE 
o = To SINGLE·PASS 
1 = To MODULO·N 


• RESERVED 


PRESCALER MODULO 
(RANGE: 1-64 DECIMAL 
01-00 HEX) 


R246 P2M 
Port 2 Mode Register 
(F6H; Write Only) 


I~I~I~I~I~I~I~I~I 


P20-P2,1I0 DEFINITION 
'------ 0 DEFINES BIT AS OUTPUT 


1 DEFINES BIT AS INPUT 


R247 P3M 
Port 3 Mode Register 
(F7H; Write Only) 


I~I~I~I~I~I~I~I~I 
E~ 


O PORT 2 PULL·UPS OPEN DRAIN 
1 PORT 2 PULL·UPS ACTIVE 


RESERVED 
o P32 = INPUT 
P35 = OUTPUT 


1 P32 = DAVOfRDYO P35 = RDYOfDAVO 


o 0 P33 = INPUT 
P34 = OUTPUT 


~~}P33 = INPUT 
P34 = Ii1II 


1 1 P33 = DAVlfRDYl P34 = RDYlfDAV1 


'--------~ 
~~1 ~ ~N:vUJ~b'~~ :~~ ~ ~~~~~UT) 


L...-_______ ~ ~~~ ~ ~N:R~rL IN 
~~~ ~ ~~~~ULT OUT 
'--________ 
~ ~~~:~~ g~F 


Figure 14. Control Registers 
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2037-014 


Registers 
(Continued) 
R248 POIM 
Port 0 and 1 Mode Register 
(F8H; Write Only) 


OUTPUT = 00 .-J . 


INPUT = 01 
, 


PO.-PO, MODE~. 


A'2-A'5 = lX 


EXTERNAL MEMORY TIMING 


NORMAL = 0 


EXTENDED = 1 ~ 


~POO_P03MODE 
L 
00 = OUTPUT 
01 = INPUT 
lX = A.-An 


. 


STACK SELECTION 


o = EXTERNAL 
1 = INTERNAL 


Plo-Pl, MODE 


00 = BYTE OUTPUT 
01 = BYTE INPUT 
10 = ADo-AD, 
11 = HIGH-IMPEDANCE ADo-AD" 


As, OS, Rm, AS-All. A12-A15 
IF SELECTED 


R249IPR 


Interrupt Priority Register 
(F9H; Write Only) 


I~I~I~I~I~I~I~I~I 


RESERVED =oJ I 


IR03, IROS PRIORITY (GROUP A) 


INTERRUPT GROUP PRIORITY 
RESERVED = 000 
C > A > B = 001 
o = IROS > IR03 
A> B > C = 010 


1 = IR03 > IROS 
A> C > B = 011 


IROO, IR02 PRIORITY (GROUP B) 
B > C > A = 100 


o = IR02 > IROO _____ 
--1 
C> B > A = 101 


1 = IROO > IR02 
B > A > C = 110 
RESERVED = 111 


IR01, IR04 PRIORITY (GROUP C) 
o = IROl > IR04 --------' 
1 = IR04 > IROl 


R250 IRQ 
Interrupt Request Register 
. 
(FAH; Read/Write) 


1~1~1~1~1~1~1~1~1 


RESERVED ~ c= 
IROO 
IROl 
IR02 
IR03 
IR04 
IROS 


R2511MR 
Interrupt Mask Register 
(FBH; Read/Write) 


I~I~I~I~I~I~I~I~I 


P32 INPUT (Do = IROO) 
P331NPUT 
P3, INPUT 
P30 INPUT, SERIAL INPUT 
To, SERIAL OUTPUT 
Tl 


: I 
c= 
1 ENABLES IROO-IROS 
(Do = IROO) 
1-. _______ RESERVED 


'----------1 ENABLES INTERRUPTS 


REGISTER 
POINTER 


R252 FLAGS 
Flag Rogister 
(FCH; Read/Write) 
I 0, I 0,1 051 0.1 031 021 0, I 
Do I 


~~~ 


LUSERFLAGFl 
LUSER FLAG F2 


HALF CARRY FLAG 


DECIMAL ADJUST FLAG 


OVERFLOW FLAG 


SIGN FLAG 


ZERO FLAG 


I-.-------CARRY FLAG 


R253 RP 


Register Pointer 
(FDH; Read/Write) 


C=DON'T CARE 


R254 SPH 


Stack Pointer 


(FEH; Read/Write) 


I~I~I~I~I~I~I~I~I 


R255 SPL 


Stack Pointer 


(FFH; Read/Write) 


I~I~I~I~I~I~I~I~I 


LI ____ ~~~~~S~~~~~~R LOWER 


Figure 14. Control Registers 
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Opcode 
Map 


o 


2 


3 


4 


5 


)( 
6 


CD =. 


CD 
:Q 
7 


:9 z .. 


CD 0. 
8· 
0. 
0 


9 


A 


B 


C 


D 


E 


F 


o 


6,5 
DEC 
Rl 


6,5 
RLC 
Rl 


6,5 
INC 
Rl 


8,0 
JP 
IRRI 


8,5 
DA 
RI 


10,5 
POP 


Rl 


6,5 
COM 


Rl 


10/12,1 
PUSH 
Rz 


10,5 
DECW 
RRI 


6,5 
RL 
Rl 


10,5 
INCW 
RRI 


6,5 
CLR 
Rl 


6,5 
RRC 


Rl 


6,5 
SRA 
'Rl 


6,5 
RR 
Rl 


8,5 
SWAP 


Rl 


6;5 
DEC 
IRI 


6,5 
RLC 
IRI 


6,5 
INC 
IRI 


6,1 
SRP 
1M 


8,5 
DA 
IRI 


10,5 
POP 
IRI 


6,5 
COM 
IRI 


12/14,1 
PUSH 
IRz 


10,5 
DECW 
IRI 


6,5 
RL 
IRI 


10,5 
INCW 
IRI 


6,5 
CLR 
IRI 


6,5 
RRC 
IRI 


6,5 
SRA 
IRI 


6,5 
RR 
IRI 


8,5 
SWAP 
IRI 


2 
3 


6,5 
6,5 


ADD 
ADD 


II, I2 
Il,II2 


6,5 
6,5 


ADC 
ADC 


II, 12 
II, Irz 


6,5 
6,5 
SUB 
SUB 
n, 12 
II, lIZ 


6,5 
6,5 
SBC 
SBC 
II, IZ 
II, lIZ 


6,5 
6,5 
OR 
OR 
II, IZ 
II, lIZ 


6,5 
6,5 


AND 
AND 


II, IZ 
II, lIZ 


6,5 
6,5 
TCM 
TCM 
II, IZ 
Il,Irz 


6,5 
6,5 


TM 
TM 


II, IZ 
Il,lIZ 


12,0 
18,0 


LDE 
LDEI 


Il,lIIZ II1,IIIZ 


12,0 
18,0 


LDE 
LDEI 


IZ, IIIl 1I2,IIIl 


6,5 
6,5 
CP 
CP 
II, 12 
II, lIZ 


6,5 
6,5 
XOR 
XOR 
fl, IZ 
n, lIZ 


12,0 
18,0 
LDC 
LDCI 
Il,lIIZ II1,IIIZ 


12,0 
18,0 
I.DC 
LDCI 
Iz,lIIl IIZ,lIIl 


6,5 
tD 
Il,II2 


6,5 
LD 


Ill, IZ 


Lower Nibble (Hex) 


4 
5 
6 
7 
8 
9 
A 
B 
C 
D 
E 
F 


10,5 
10,5 
10,5 
10,5 
6,5 
6,5 
12110,5 
12/10,0 
6,5 
12/10,0 
6,5 


ADD 
ADD 
ADD 
ADD 
LD 
LD 
DJNZ 
JR 
LD 
JP 
INC 


R2,Rl 
IR2,Rl 
Rl,lM 
IRl,lM 
Il,R2 
12,Rl 
fl,RA 
cc,RA 
Il,lM 
cc,DA 
II 
10,5 
10,5 
10,5 
10,5 
r--- 


ADC 
ADC 
ADC 
ADC 
R2,Rl -IRz,Rl 
Rl,lM 
IRl,lM 
r--- 
10,5 
10,5 
10,5 
10,5 


SUB 
SUB 
SUB 
SUB 


R2,Rl 
IRz,Rl 
Rl,lM 
IRl,lM 
r--- 
10,5 
10,5 
10,5 
10,5 


SBC 
SBC 
SBC 
SBC 


R2,Rl 
IRz,Rl 
Rl,lM 
IRl,lM 
r--- 
10,5 
10,5 
10,5 
10,5 


OR 
OR 
OR 
OR 
R:z,RI 
IR:z,RI 
RI,IM 
IRI,IM 
r--- 
10,5 
10,5 
10,5 
10,5 


AND 
AND 
AND 
AND 


Rz,Rl 
IRz,Rl 
Rl,lM 
IRl,IM 
r--- 
10,5 
10,5 
10,5 
10,5 
TCM 
TCM 
TCM 
TCM 
Rz,Rl 
IRz,Rl 
Rl,lM 
IRl,lM 
r--- 
10,5 
10,5 
10,5 
10,5 


TM 
TM 
TM 
TM 


Rz,Rl 
IR2,Rl 
Rl,lM 
IR1,IM 
I-- 
6,1 
DI 


r--- 
6,1 
El 
I-- 
10,5 
10,5 
10,5 
10,5 
14,0 
CP 
CP 
CP 
CP 
RET 
R2,Rl 
IRZ,Rl 
Rl,lM 
IRl,lM 
,- 
10,5 
10,5 
10,5 
10,5 
16,0 
XOR 
XOR 
XOR 
XOR 
IRET 
Rz,Rl 
IRZ,Rl 
Rl,lM 
IR1,IM 
i--- 
10,5 
6,5 
LD 
RCF 
II, x, Rz 
- 
20,0 
20,0 
10,5 
6,5 
CALL· 
CALL 
LD 
SCF 
IRRI 
DA 
12, X, Rl 
~ 
10,5 
10,5 
10,5 
10,5 
6,5 
tD 
tD 
tD 
LD 
CCF 
R2,Rl 
IR2,Rl 
Rl,lM 
IR1,IM 
f- 
10,5 
6,0 
LD 
W 
1 
It 
, 
NOP 
Rz,IRl 


\, 
~ "- 
ttl 
\, 


Bytes per 
'-r' 
'-r' 
'---------~~~----------~# ~ 
~ 


Instruction 
2 
3 
Lower 
Opcode 
Nibble 


Execution 
+ 
Pipeline 
Cycles 
Cycles 


Upper 
Opcode~A 
Mnemonic 
Nibble 


First 
S,econd 
Operand 
Operand 


*2-byte instruction; fetch cycle appears as a 3-byte instruction 
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2 


Legend: 
R = 8-Bit Address 
r = 4-Bit Address 
RI or rl = Dst Address' 
R2 or r2 = Src Address 


Sequence: 


3 


Opcode, First Operand, Second Operand 


Note: The blank areas are not defined. 


8085-002 


Absolute 
Maximum 
Ratings 


Standard 
Test 
Conditions 


DC 
, Character- 
istics 


Voltages on all pins 
with respect to GND .......... -0.3 V to + 7.0 V 
Operating Ambi'ent 
Temperature ........ See Ordering Information 


Storage Temperature ........ -65°C to + 150°C 


The characteristics below apply for the 
following standard test conditions, unless 
otherwise noted. All voltages are referenced to 
GND. Positive current flows into the reference 
pin. Standard conditions are as follows: 


+SV 


Stresses greater than those listed under Absolute Maxi- 
mum Ratings may cause permanent damage to the device. 
This is a stress rdting only; operation of the device at any 
condition above those indicated in the operational sections 
of these specifications is not implied. Exposure to absolute 
maximum rating conditions for extended periods may affect 
device reliability. 


o +4.75 V ~ Vee ~ +5.25 V 
o GND = a V 
o O°C ~ TA ~ +70°C* 


·See Ordering Information section for package 
temperature range and product number. 


+SV 
+5V 


18K 


+SV 


1.Sk 
1.Sk 


CLOCK 
IN 


74LS04 
74LS04 


>O---.--t.:»-<~...-- XTAL2 


I ! 
CL = lSpF MAX 


L...-----t'-- XTAL1 


I I 
CL = lSpF MAX 


Figure 15. Test Load 1 
Figure 16. Test Load 2 
Figure 17. TTL External Clock ~ llterface Circuit 
(Both the clock and its complement are required) 


Symbol 
Parameter 
Min 
Max 
Unit 
Condition 
Notes 


VeH 
Clock Input High Voltage 
3.8 
Vec 
V 
Driven by External Clock Generator 


VCL 
Clock Input Low Voltage 
-0.3 
0.8 
V 
Driven by External Clock Generator 


VIH 
Input High Voltage 
2.0 
Vee 
V 


VlL 
Input Low Voltage 
-0.3 
0.8 
V 


VRH 
Reset Input High Voltage 
3.8 
Vce 
V 


VRL 
Reset Input Low Voltage 
-0.3 
0.8 
V 


VOH 
Output High Voltage 
2.4 
V 
IOH = -250 p.A 


VOL, 
Output Low Voltage 
0.4 
V 
IoL = +2.0 rnA 


IlL 
Input Leakage 
-10 
10 
p,A 
o V::s; VIN ::s; +5.25 V 


IOL 
Output Leakage 
-10 
10 
p,A 
o V::s; VIN ::s; +5.25 V 


IIR 
Reset Input Current 
-50 
p,A 
Vcc = +5.25 V, VRL = 0 V 


Icc 
V CG Supply Current 
180 
rnA 


IMM 
VMM Supply Current. 
10 
rnA 
Power Down Mode 


VMM 
Backup Supply Voltage 
3 
Vec 
V 
Power Down 


1. For AO-All' MDS, SYNC, SCLK and lACK on the Z8612 version, lOH = -100 p.A and lOL = 1.0 rnA. 


8085-0313, 0312 
2037-015 
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= 
0') ... ... -... 
N -... 
w 
I 


External 110 
or Memory 
Read and 
Write Timing 


No. 
Symbol 


TdA(AS) 


2 
TdAS(A) 


3 
TdAS(DR) 


4 
TwAS 


5 
TdAz(DS) 
6-TwDSR 


7 
TwDSW 


8 
TdDSR(DR) 


9 
ThDR(DS) 


10 
TdDS(A) 


11 
TdDS(AS) 


RlW 


PORT 0, 


DM 


PORT 1 


. 0l----.a~1 


os 


(READ) 


------------4---------~'~~--------~CDr---------~'z_----r_---- 


PORT 1 


os 
(WRITE) 


Ao-A7 
00-07 OUT 


1~------4CDr-----~~1 


Figure 18. External I/O or Memory Read/Write 


Z8611/2/3 
Z8611/2/3-12 
Parameter 
Min 
Max 
Min 
Max 


Address Valid to AS I Delay 
50 
35 


AS I to Address Float Delay 
70 
45 


AS I to Read Data Required Valid 
360 
220 


AS Low Width 
80 
55 


Address Float to DSI 
0 
0 


DS (Read) Low Width 
250 
185 


DS (Write) Low Width 
160 
110 


DS I to Read Data Required Valid 
200 
130 


Read Data to DS I Hold Time 
0 
0 


DS I to Address Active Delay 
70 
45 


DS I to AS I Delay 
70 
55 


12 - 
TdRlW(AS) --' R/W Valid to AS I Delay 
50 
30 


13 
TdDS(R/W) 
DS I to R/W Not Valid 
60 
35 


14 
TdDW(DSW) 
Write Data Valid to DS (Write) I Delay 
50 
35 


15 
TdDS(DW) 
DS I to Write Data Not Valid Delay 
70 . 
45 


16 
TdA(DR) 
Address Valid to Read Data Required Valid 
410 
255 


17 
TdAS(DS) 
AS I to DS I Delay 
80 
55 


NOTES: 


Notes*t 


1,2,3 


1,2,3 


1,2,3,4 


1,2,3 


1,2,3,4 


1,2,3,4 


1,2,3,4 


1 


1,2,3 


1,2,3 


1,2,3 


1,2,3 


1,2,3 


1,2,3 


1,2,3,4 


1,2,3 


1. Test Load 1 
5. All timing references use 2.0 V for a logic "I" and 0.8 V for a logic "0". 


2. Timing numbers given are for minimum TpC. 
• All units in nanoseconds (ns). 
3. Also see clock cycle time dependent characteristics table. 
t Timings are preliminary and subject to change. 
4. When using extended memory timing add 2 TpC. 
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2194-011 


Additional 
Timing 
Table 


No. 
Symbol 


TpC 


2 
TrC,TfC 


3 
TwC 


4 
TwTinL 
5-TwTinH 


6 
TpTin 


7 
TrTin, TfTin 


8a 
TwIL 


8b 
TwIL 


9 
TwIH 


NOTES: 


Parameter 


Input Clock Period 


Clock Input Rise And Fall Times 


Input Clock Width 
Timer Input Low Width 


Timer Input High Width 


Timer Input Period 
Timer Input Rise And Fall Times 


Interrupt Request Input Low Time 


Interrupt Request Input Low Time 
Interrupt Request Input High Time 


1. Clock timing references uses 3.8 V for a logic "1" and 0.8 V for 
a logic "0". 


2. Timing reference uses 2.0 V for a logic "I" and 0.8 V for 
a logic "0" 


Figure 19. Additional Timing 


Z8611/2/3 
Z861112/3·12 
Min 
Max 
Min 
Max 


125 
1000 
83 
1000 


25 
15 


37 
26 


100 
70 


3TpC 
3TpC 


8TpC 
8TpC 


100 
100 


100 
70 


3TpC 
3TpC 


3TpC 
3TpC 


3. Interrupt request via Port 3 (P31-P33)' 
4. Interrupt request via Port 3 (P30)' 
• Units in nanoseconds (ns). 
t Timings are preliminary and subject to change. 


Z8612. Z8613 
Memory Port 
Timing 


AO-A10 ~ 
ADDRESS VALID 
t( 


_----J 
____ T-_=.~-_==-_==~-0=r=-_==--~~~-------------------~T~1~ 


No. 
Symbol 


2 


NOTES: 


TdA(DI) 
ThDI(A) 


DON'T CARE 
,Xl; 
DATA IN VALID 
~ 


Figure 20. Memory Port Timing 


Parameter 


Address Valid to Data Input Delay 


Data In Hold Time 


Z861112/3 
Min 
Max 


460 


o 


Z861112/3·12 
Min 
Max 


320 


o 


Notes*t 


1 


2 


2 
2 


2 
2,3 


2,4 


2,3 


Notes* 


1,2 


1. Test Load 2 
2. This is a Clock-Cycle-Dependent parameter. For clock frequen- 
cies other than the maximum, use the following formula: 
28611/2/3 = 5 TpC - 
165 


• Units are nanoseconds unless otherwise specified; timings are. 
preliminary and subject to change. 


28611/2/3-12 = 5 TpC - 95 


2194-012 2037-019 
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II 
en ... ... - 
... 
~ -... 
W 
I 


Handshake 
Timing 
DATA IN 


DAY 


(INPUT) 


RDY 


(OUTPUT) 


DATA OUT 


Figure 21a. Input Handshake 
r- 
~ATA OUT VALID 
-~---- 


1~: 
-®>----~-Er= 


No. 
Symbol 


DAY 


(OUTPUT) 


RDY 


(INPUT) 


Parameter 


TsDI(DAV) 
Data In Setup Time 


2 
ThDI(DA V) 
Data In Hold Time 


3 
TwDAV 
Data Available Width 


Figure 21b. Output Handshake 


Z8611/2/3 
Z8611/2/3-12 
Min 
Max 
Min 
Max 


0 
0 


230 
160 


175 
120 


Notes*t 


4 
TdDAVIf(RDY) 
DAV 1 Input to RDY 1 Delay 
175 


5-TdDAVOf(RDY)-DAV 1 OutputtoRDY 1 Delay -------- 0 
0 


120 
1,2 
-------1,3 


6 
TdDAVIr(RDY) 
DAV t Input to RDY t Delay 


7 


8 


9 


NOTES: 


TdDAVOrRDY) 


TdDO(DAV) 


TdRDY(DAV) 


I. Test load I 
2. Input handshake 
3. Output handshake 


DAV t Output to RDY t Delay 


Data Out to DA V 1 Delay 


Rdy 1 Input to DAV t Delay 


4. All timing regerences use 2.0 V for a logic "I" and 0.8 V for 
a logic "0" 


Clock- 
Cycle-Time- 
Number 
Symbol 
Dependent 
TdA(AS) 
Characteristics 
2 
TdAS(A) 


3 
TdAS(DR) 


4 
TwAS 


6 
TwDSR 


7 
TwDSW 
8 
TdDSR(DR) 


10 
Td(DS)A 


11 
TdDS(AS) 


12 
TdR/W(AS) 


13 
TdDS(R/W) 


14 
TdDW(DSW) 


15 
TdDS(DW) 


16 
TdA(DR) 


17' 
TdAS(DS) 


• Add 2TpC when using extended memory timing 


520 


175 
120 


0 
0 


50 
30 


0 
200 
0 
140 


• Units in nanoseconds (ns). 
r Timings are preliminary and subject to change. 


Z8611/2/3 
Z8611/2/3-12 
Equation 
Equation 


TpC-75 
TpC-50 


TpC-55 
TpC-40 
4TpC-140* 
.4TpC-llO* 


TpC-45 
TpC-30 


3TpC-125* 
3TpC-65* 


2TpC-90* 
2TpC-55* 


3TpC-175* 
3TpC-120* 


TpC-55 
TpC-40 


TpC-55 
TpC-30 


TpC-75 
TpC-55 


TpC-65 
TpC-50 


TpC-75 
TpC-50 


TpC-55 
TpC-40 


5TpC-215* 
5TpC-160* 


TpC-45 
TpC-30 


1,2 


1,3 


2194-013 


Ordering 
Product 
Package/ 
Product 
Package/ 
Information 
Number 
Temp 
Speed 
Description 
Number 
Temp 
Speed 
Description 


28611 
CE 
8.0 MHz 
28MCU 
28612 
PE 
8.0 MHz 
28MCU 


(4K ROM, 40-pin) 
28612 
(4K XROM, 64-pin) 


28611 
CS 
8.0 MHz 
Same as above 
28612-12 
PS 
8.0 MHz 
Same as above 
28611 
PE 
8.0 MHz 
Same as above 
CE 
12.0 MHz 
Same as above 
28611 
PS 
8.0 MHz 
Same as above 
28612-12 
CS 
12.0 MHz 
Same as above 
28611-12 
CE 
12.0 MHz 
28MCU 
28612-12 
PE 
12.0 MHz 
Same as above 
(4K ROM, 40-pin) 
28612-12 
PS 
12.0 MHz 
Same as above 
28611-12 
CS 
12.0 MHz 
Same as above 
28613 
RS 
8.0 MHz 
28 MCU (4K XROM, 


28611-12 
PE 
12.0 MHz 
Same as above- 
Prototyping Device, 
28611-12 
PS 
12.0 MHz 
Same as above 
40-pin) 


28612 
CE 
8.0 MHz 
Z8MCU 
28613-12 
RS 
12.0 MHz 
Same as above 
(4K XROM, 64-pin) 


28612 
CS 
8.0 MHz 
Same as above 


NOTES: C = Ceramic, P = Plastic, R = Prototyping Device; E = -40° to +85°C, S = O°C to +70°C. 
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Zilog 


Features 


General 
Description 


2150·001,002 


IJ The 28671 MCU is a complete micro- 
computer preprogrammed with a BASIC/ 
Debug interpreter. Interaction between the 
interpreter and its user is provided through 
an on-board UART. 


IJ BASIC/Debug can directly address the 
28671' s internal registers and all external 
memory. It provides quick examination and 
modification of any external memory loca- 
tion or I/O port. 


The 28671 Single-Chip Microcomputer 


(MCU) is one of a line of preprogrammed 
chips-in this case with a BASIC/Debug inter- 
preter in ROM-offered by 2ilog. As a member 
of the 28 Family of microcomputers, it offers 
the same abundance of resources as the other 
28 microcomputers. 
Because the BASIC/Debug interpreter is 
already part of the chip circuit, programming 
is made much easier. The 28671 MCU thus 
offers a combi'nation of software and hardware 
that is ideal for many industrial control appli- 


[- 


RESET 
+5V 


TIMING 
R/W 
GND 
AND 


CONTROL 
os 
XTALl 


AS 
XTAL2 


POo 
P20 


PO, 
P2, 


P02 
P22 
PORTO 
PO, 
P2, 
PORT 2 


(NIBBLE 
(BIT PRO· 
PROGRAMMABLE) 
PO. 
P2. 
GRAMMABLE) 


110 or Aa-A'5 
110 
POs 
Z8671 
P2s 


PO. 
MCU 
P2, 


PO, 
P2, 


Pl 0 
P30 
Pl, 
P3, 


P1 2 
P32 
PORT 3 


Pl, 
P3, 
(FOUR INPUT; 


PORT 1 
FOUR OUTPUn 


110 OR ADo-AD, 
Pl. 
P3. 
SERIAL AND 
PARALLEL 110 
Pl. 
P3s 
AND CONTROL 
Pl. 
P3, 


Pl, 
P3, 


Figure 1. Pin Functions 


~8® Irammiiny 


~3~ 7 n r~(CUJ wiinlhl 
rnll!X§ll<C/lIDe 1hHUl~ ilmlReI?R»I?eReI? 


1P> [(<mail un «:fr - 


~]lD (9ciiaiicCID. Rn«J)Inl 


September 1983 


o The BASIC/Debug interpreter can call 
machine language subroutines to increase 
execution speed. 


o The 28671's auto start-up capability allows a 
program to be executed on power-up or 
Reset without operator intervention. 


o Single + 5 V power supply-all I/O pins 
TTL-compatible. 


r:J 8 MHzll2 MHz 


cations. The 28671 MCU allows fast hardware 
tests and bit-by-bit examination and modifica- 
tion of memory location, I/O ports, or 
registers. It also allows bit manipulation and 
logical operations. A self-contained line editor 
supports interactive debugging, further 
speeding up program development. 
The BASIC/Debug interpreter, a subset of 
Dartmouth BASIC, operates with three kinds of 
memory: on-chip registers and external ROM 
or RAM. The BASIC/Debug interpreter is 
located in the 2K bytes of on-chip ROM. 


+5V 
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XTAL2 
P3, 


XTAl1 
P2, 


P3, 
P2, 


P30 
P2s 
fjESET 
P2. 


R/W 
P2, 
os 
P22 
AS 
P2, 


P35 
P20 


GND 
P3, 


P32 
P3. 


POo 
P17 


PO, 
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P02 
Pls 


PO, 
Pl, 
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Pl, 


POs 
P12 


PO, 
Pl, 


PO, 
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Figure 2. Pin Assignments 
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General 
Description 
(Continued) 


Additiorial features of the 28671 MCU 
include the ability to call machine language 
subroutines to increase execution speed and 
the ability to have a program execute on 
power-up or Reset, without operator 
intervention. 
Maximum memory addressing capabilities 
include 62K bytes of external program memory 


OUTPUT 
INPUT 
Vee 
GND 


and 62K bytes of data memory with program 
storage beginning at location 800 hex. This 
provides up to 124K bytes of useable memory 
space. Very few 8-bit microcomputers can 
directly access this amount of memory. 
Each Z8671 Microcomputer has 32 I/O lines, 
a 144-byte register file, an on-board UART, 
and two counter/timers. 


AS 


~/,----!_! 
_,\I~--'--1 


UART 


,IL-....:-.-~ 
!lllll!l 


I/O 
(BIT PROGRAMMABLE) 


FLAGS 


REG, POINTER- 


ADDRESS OR I/O 
(NIBBLE PROGRAMMABLE) 


Figure 3. Functional Block Diagram 


ADDRESSfDATA OR I/O 
(BYTE PROGRAMMABLE) 


Architecture 
Z8671 architecture is characterized by a 
microprocessor that can address 124K bytes of 
external memory. 
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flexible I/O scheme, an efficient register and 
address space structure, and a number of 
ancillary features that are helpful in many 
applications. 
Microcomputer applications demand power- 
ful I/O capabilities. The Z8671 fulfills this with 
32 pins dedicated to input and output. These 
lines are grouped into four ports of eight lines 
each and are configurable under software con- 
trol to provide timing, status signals, serial or 
parallel I/O with or without handshake, and an 
address/data bus for interfacing external 
memory. 
Because the multiplexed address/data bus is 
merged with the I/O-oriented ports, the Z8671 
can assume many different memory and I/O 
configurations. These configurations range 
from a self-contained microcomputer to a 


Three basic address spaces are available to 


supporUhis wide range of configurations: pro- 
gram memory (internal and external), data 
memory (external) and the register file (inter- 
nal). The 144-byte random-access register file 
is composed of 124 general-purpose registers, 
four I/O port registers, and 16 control and 
status registers. 
To unburden the program from coping with 
real-time problems such as serial data com- 
munication and counting/timing, an asynchro- 
nous receiver/transmitter (UART) and two 
counter/timers with a large number of user- 
selectable modes are offered on-chip. Hard- 
ware support for theUART is minimized 
because one of the on-chip timers supplies the 
bit rate. 


2037-003 


Pin 
Description 


Address 
Spaces 


AS. Address Strobe (output, active Low). 
Address Strobe is pulsed once at the begin- 
ning of each machine cycle. Addresses output 
via Port 1 for all external program or data 
memory transfers are valid at the trailing edge 
of AS. Under program control, AS can be, 
placed in the high-impedance state along with 
Ports 0 and 1, Data Strobe and Read/Write. 
OS. Data Strobe (output, active Low). Data 
Strobe is activated once for each external 
memory transfer. 


POO-P07, P1o-P17' P2o-P27, P30-P37. 1/0 Port 
Lines (inpuVoutputs, TTL-compatible). These 
32 lines are divided into four 8-bit I/O ports 
that can be configured under program control 


Program Memory. The 28671' s 16-bit program 
counter can address 64K bytes of program 
memory space. Program memory consists of 2K 
bytes of internal ROM and up to 62K bytes of 
external ROM, EPROM, or RAM. The first 12 
bytes of program memory are reserved for 
interrupt vectors (Figure 4). These locations 
contain six 16-bit vectors that correspond to 
the six available interrupts. The BASIC/Debug 
interpreter is located in the 2K bytes of inter- 
nal ROM. The interpreter begins at address 12 
and extends to 2047. 
Data Memory. The 28671 can address up to 
62K bytes of external data memory beginning 
at location 2048 (Figure 5). External data mem- 
ory may be included with, or separated from, 
the external program memory space. DM, an 
optional I/O function that can be programmed 
to appear on pin P34, is used to distinguish 
data and program memory space. 
Register File. The 144-byte register file may 
be accessed by BASIC programs as memory 
locations 0-127 and 240-255. The register file 
includes four I/O port registers (RO-R3), 124 
general-purpose registers (R4-R127), and 16 
control and status registers (Figure 6). 


Location 0 
first byte 0 
instruction 


I 
I 


5535 


2048 
2047 


EXTERNAL 


ROM OR RAM 


ON·CHIP 
ROM 


executed 
afterrese t~ :;:------------- 


t 


I 


Interrup 
Vector 


(lower Byte 


Inlerrept 
Vector 


(Upper Byte I 


11 


10 


9 


8 


7 


6 


5 ...... 
4, 


3 


2 


1 


0 


IRQ5 


IRQ5 


IRQ4 


IRQ4 


IRQ3 


IRQ3 


IRQ2 


IRQ2 


IRQl 


IRQl 


IRQO 


IRQO 


} 
'''''' 
DEBUG 


Figure 4. Program Memory Map 


2150-003, 2037-005, 2150-004 


for I/O or external memory interface. 


RESET. Reset (input, active Low). RESET ini- 
tializes the 28671. When RESET is deactivated, 
program execution begins from internal pro- 
gram location OOOCH. 
R/W. Read/Write (output). RlW is Low when 
the 28671 is writing to external program or 
data memory. 
XTALL XTAL2. Crystal], Crystal 2 (time-base 
input and output). These pins connect a 
parallel-resonant crystal (8 or 12 MHz max- 
imum) or an external single-phase clock (8 or 
12 MHz maximum) to the on-chip clock 
,oscillator and buffer. 


The BASIC/Debug Interpreter uses many of 
the general-purpose registers as pointers, 
scratch workspace, and internal variables. 
Consequently, these registers cannot be used 
by a machine language subroutine or other 
user programs. On power-up/Reset, BASIC/ 
Debug searches for external RAM memory and 


65535 r-----------, 


EXTERNAL 
DATA 


MEMORY 


~g!~ 1------------1 


NOT ADDRESSABLE 


Figure 5. Data Memory Map 


LOCATION 


255 
STACK POINTER (BITS 7-0) 


254 
STACK POINTER (BITS 15-8) 


253 
REGISTER POINTER 


252 
PROGRAM CONTROL FLAGS 


251 
INTERRUPT MASK REGISTER 


250 
INTERRUPT REQUEST REGISTER 


249 
INTERRUPT PRIORITY REGISTER 


248 
PORTS 0-1 MODE 


247 
PORT 3 MODE 


246 
PORT 2 MODE 


245 
TO PRESCALER 


244 
TIMER/COUNTER 0 


243 
Tl PRESCALER 


242 
TIMER/COUNTER 1 


241 
TIMER MODE 


240 
SERIAL I/O 


NOT 
IMPLEMENTED 


IDENTIFIERS 


SPL 


SPH 


RP 


FLAGS 


IMR 


IRQ 


IPR 


P01M 


P3M 


P2M 


PREO 


TO 


PREl 


T1 


TMR 


SIO 


Figure 6. Control and Status Registers 
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Address 
Spaces 
(Continued) 
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127 


EXPRESSION 
EVALUATION 
STACK 


64 
63 


FRE:: 


34 
33 


COUNTER 


32 


31 
USED INTERNALLY 


30 
SCRATCH 


29 
POINTER TO 
23 
CONSTANT ElLOCK 


27 


USED INTERNALLY 


24 
23 
LINE NUMBER 
22 
21 
ARGUMEtJT FOR 
20 
SUBROUTINE 


19 
ARGUIr.ENTIF10UTIN" FOR 


18 
SUSFlOUTINE CALL 


17 


SCRATCH 
16 
15 
POINTER TO INPUT 


14 
LINE BUFrER 


13 
POINTER TO END OF 


12 
LINE BUFFER 


11 
POINTER TO STACK 
10 
BOTTOM 


9 
ADDRESS OF USER 
PROGRAM 


POINTER TO GOSUB 
STACK 


POINTER TO END 
OF PROGRAM 


I/O PORTS 


Figure 7a.. General-Purpose Registers 


with Externc:tl RAM 


checks for an auto start-up program. In a non- 
destructive method, memory is tested at 
relative location xxFD(hex). When BASIC/ 
Debug discovers RAM in the system, it ini- 
tializes the pointer registers to mark the 
boundaries between areas of memory that are 
assigned specific uses. The top page of RAM is 
allocated for the line buffer, variable storage, 
and the GOSUB stack. Figure 7a illustrates the 
contents of the general-purpose registers in the 
Z8671 system with external RAM. When 
BASIC/Debug tests memory and finds no 
RAM, it uses an internal stack and shares 
register space with the input line buffer and 
variables. Figure 7b illustrates the contents of 
the general-purpose registers in the Z8671 
system without external RAM. 
Stacks. Either the internal register file or the· 
external data memory can be used for the 
stack. A 16-bit Stack Pointer (R254 and R255) 
is used for the external stack, which can reside 
anywhere in data memory between location 
2048 and 65535. An 8-bit Stack Pointer (R255) 
is used for the internal stack that resides within 
the 124 general-purpose registers (R4-R127). 
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Figure 7b. General-Purpose Registers 
without External RAM 
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The upper "Ibble of the register tile address 
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the active working-register group. 
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Figure 8. The Register Pointer 


2150·005, 2037-007 


Address 
Spaces 
(Continued) 


Program 
Execution 


Interactive 
Debugging 


Commands 


Register Addressing. 28671 instructions can 
access registers directly or indirectly with an 
8-bit address field. The 28671 also allows short 
4-bi t register addressing using the Register 
Pointer (one of the control registers). In the 


Automatic Start-up. The 28671 has an 
automatic start-up capability which allows a 
program stored in ROM to be executed without 
operator intervention. Automatic execution 
occurs on power-on or Reset when the pro- 
gram is stored at address 1020 (hex). 


Execution Modes. The 28671's BASIC/Debug 
Interpreter operates in two execution modes: 
Run and Immediate. Programs are edited and 


Interactive debugging is accomplished with 
the self-contained line editor which operates in 
the Immediate mode. In addition to changing 
program lines, the editor can correct an imme- 
diate command before it is executed. It also 
allows the correction of typing and other errors 
as a program is 'entered. 
BASIC/Debug allows interruptions and 
changes during a program run to correct 


BASIC/Debug recognizes 15 command 
keywords. For detailed instructions of com- 
mand usage, refer to the BASIC/Debug Soft- 
ware Reference Manual (#03-3149-02). 
GO 
The GO command unconditionally 
branches to a machine language 
subroutine. This statement is 
similar to the USR function except 
that no value is returned by the 
assembly language routine. 


GOSUB 
GOSUB unconditionally branches 
to a subroutine at a line number 
specified by the user. 


GOTO 
GOTO unconditionally changes 
the sequence of program execution 
(branches to a line number). 


IF/THEN 
This command is used for condi- 
tional operations and branches. 


INPUT/IN These commands request informa~ 


tion from the user with the prompt 
\I?", then read the input values 
(which must be separated by com- 
mas) from the keyboard, and store 
them in the indicated variables. 
INPUT discards any values remain- 
ing in the buffer from previous IN, 
INPUT, or RUN statements, and 
requests new data from the 
operator. IN uses any values left in 


4-bit mode, the register file is divided into 
nine working-register groups, each group con- 
sisting of 16 contiguous registers (Figure 8). 
The Register Pointer addresses the starting 
location of the active working-register group. 


interactively debugged in the Immediate 
mode. Some BASIC/Debug commands are 
used almost exclusively in this mode. The Run 
mode is entered from the Immediate mode by 
entering the command RUN. If there is a pro- 
gram in RAM, it is executed. The system 
returns to the Immediate mode when program 
execution is complete or interrupted by an 
error. 


errors and add new instructions without 
disturbing the sequential execution of the 
program. A program run is interrupted with 
the use of the escape key. The run is restarted 
with a GOTO command (followed by the 
appropriate line number) after the desired 
changes are entered. The same procedure is 
used to enter corrections after BASIC/Debug 
returns an error. 


LET 


LIST 


NEW 


PRINT 


the buffer first, then requests new 
data. 


LET assigns the value of an 
expression to a variable or memory 
location. 


This command is used in the inter- 
active mode to generate a listing of 
program lines stored in memory on 
the terminal device. 


The NEW command resets pointer 
RlO-11 to the beginning of user 
memory, thereby mar king the 


~pace as empty and ready to store 
a new program. 


PRINT lists its arguments, which 
may be text messages or nuinerical 
values, on the output terminal. 


REM 
This command is used to insert 
explanatory messages into the 
program. 


RETURN 
This command returns control to 
the line following a GOSUB 
statement. 


RUN 
RUN initiates sequential execution 
of all instructions in the current 
program. 


STOP 
STOP ends program execution and 
clears the GOSUB stack. 
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BASIC/Debug supports two functions: AND 
and USR. 


The AND function performs a logical AND. 
It can be used to mask, turn off, or isolate bits. 
This function is used in the following format: 


AND (expression, expression) 


The two expressions are evaluated, and their 
bit patterns are ANDed together. If only one· 
value is included in the parentheses, it is 
ANDed with itself. A logical OR can also be 
performed by complementing the AND func- 
tion. This is accomplished by subtracting each 
expression from -1. For example, the function 
below is eqUivalent to the OR of A and B. 


-1-AND(-I-A, -I-B) 


Port 3 lines P30 and P37 can be programmed 
as serial I/O lines for full-duplex serial asyn- 
chronous receiver/transmitter operation. The 
bit rate is controlled by Counter/Timer 0, with 
a maximum rate of 62.5K bits/second for 
8MHz, and a maximum rate of 94.8K bits/se- 
cond for 12MHz parts. 
The 28671 automatically adds a start bit and 
two stop bits to transmitted data (Figure 9). 
Odd parity is also available as an option. Eight . 


T 


LSTART BIT 
'------EIGHT DATA BITS 


TWO STOP BITS 


Transmitted Data 
(No Parity) 


I~I~I pl~I~I~I~I~I~I~ls~ 
T 


I, _ _ 
LSTARTBIT 
L------SEVEN DATA BITS 


ODD PARITY 


T'NO STOP elTS 


Transmitted Data 
(With Parity) 


The· USR function calls a machine language 
subroutine and returns a value. This is useful 
for applications in which a subroutine can be 
performed more quickly and effiCiently in 
machine language than in BASIC/Debug. 
The address of the first instruction of the 
subroutine is the first argument of the USR 
function. The address can be followed by one 
or two values to be processed by the 
subroutine. In the following example, 
BASIC/Debug executes the subroutine located 
at address 2000 using values literal 256 and 
variable C. 


USR(%2000,256,C) 


The resulting value is stored in Registers 
18-19. 


data bits are always transmitted, regardless of 
parity selection. If parity is enabled, the eighth 
data bit is used as the odd parity bit. An inter- 
rtlpt request (lRQ4) is generated on all 
transmitted characters. 
Received data must have a start bit, eight 
data bits, and at least one stop bit. If parity is 
on, bit 7 of the received data is replaced by a 
parity error flag. Received characters generate 
the IRQ3 interrupt request. 


I~I~I~I~I~I~I~I~I~I"I 


LSTART BIT 
'------EIGHT DATA BITS 
'----------ONE 
STOP BIT 


Received Data 
(No Parity) 


1~lpl~I~I~I~I~I~I~I"1 


II, __ 
LSTARTBIT 
'-----SEVEN DATA BITS 


PARITY ERROR FLAG 


'-----------ONE STOP BIT 


Received Data 
(With Parity) 


Figure 9. Serial Data Formats 


2037·009 


I/O Ports 


2037-008 


The 28671 has 32 lines dedicated to input 
and output. These lines are grouped into four 
ports of eight lines each and are configurable 
as input, output or address/data. Under soft- 
ware control, the ports can be programmed to 


Port 1 can be programmed as a byte I/O 


port or as an address/data port for interfacing 
, external memory. When used as an I/O port, 
Port 1 may be placed under handshake con- 
trol. In this configuration, Port 3 lines ·P33 and 
P34 are used as the handshake controls RDY 1 
and DAV1 (Ready and Data Available). 
Memory locations greater than 2048 are 
referenced through Port 1. To interface exter- 
nal memory, Port 1 must be programmed 
for the multiplexed Address/Data mode. If 
more than 256 external locations are required, 
Port 0 must output the additional lines. 


Port 1 can be placed in the high-impedance 
state along with Port 0, AS, DS and R/W, 


Port 0 can be programmed as a nibble I/O 


port, or as an address port fo~ interfacing 
external memory. When used as an I/O port, 
Port 0 may be placed under handshake con- 
trol. In this configuration, Port 3 lines P32 and 
P3s are used as the handshake controls DA Vo 
and RDYo. Handshake signal assignment is 
dictated by the I/O direction of the upper 
nibble P04-P07. 


For external memory references, Port 0 can 
provide address bits As-All (lower nibble) or 
Ag-A1S (lower and upper nibble) depending 
on the required address space. If the address 
, range requires 12 bits or less, the upper nibble 
of Port 0 can be programmed independently as 


Port 2 bits can be programmed inde- 
pendently as input or output. The port is 
always available for I/O operations. In addi- 
tion, Port 2 can be configured to provide 
open-drain outputs. 
Like Ports 0 and I, Port 2 may also be 
placed under handshake control. In this con- 
figuration, Port 3 lines P31 and P36 are used as 
the handshake controls lines DAV2 and RDY2. 
The handshake signal assignment for Port 3 
lines P31 and P36 is dictated by the direction 
(input or output) assigned to bit 7 of Port 2. 


Port 3 lines can be configured as I/O or con- 
trol lines. In either case, the direction of the 
eight lines is fixed as four input (P30-P33) anq 
four output (P34-P37). For serial I/O, lines P30 
and P37 are programmed as serial in and serial 
out respectively. 


Port 3 can also provide the following control 
functions: handshake for Ports 0, 1 and 2 
(DAV and RDY); four external interrupt 
request 'signals (IRQO-IRQ3); timer input and 
output signals (TIN and TOUT) and Data 
Memory Select (DM). 


provide address outputs, timing, status signals, 
serial I/O, and parallel I/O with or without 
handshake. All ports have active pull-ups and 
pull-downs compatible with TTL loads. 


allowing the 28671 to share common resources 
in multiprocessor and DMA applications. Data 
transfers can be controlled by assigning P33 as 
a Bus Acknowledge input and P34 as a Bus 
Request output. 


f--a--\ PORT 1 
~ 
110 or ADa-AD1 


} 
HANDSHAKE CONTROLS 
DAV, AND ROY, 
(P33 AND P3.) 


Figure lOa. Port 1 


I/O while the lower nibble is used for address- 
ing. When Port 0 nibbles are defined as 
address bits,' they can be set to the high- 
impedance state along with Port 1 and the con- 
trol signals AS, DS and R/W. 


} 


PORT 0 
(1/0 OR A.-A,sl 


_ 
} HANDSHAKE CONTROLS 


DAVa AND RDYo 
(P3, AND P3sl 
. 


Figure 10b.- Port 0 


} 
HANDSHAKE CONTROLS 
IiAV2 AND RDY2 
(P3, AND P3S> 


Figure lOco Port 2 


PORT 3 
(1/0 OR CONTROL) 


Figure 10d. Port 3 
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The Z8671 contains two 8-bit programmable 
counter/timers (To and Tl), each driven by its 
own 6-bit programmable prescaler. The Tl 
prescaler can be driven by internal or external 
clock sources; however, the To prescaler is 
driven by the internal clock only. 
The 6-bit prescalers can divide the input fre- 


quency of the clock source by any number 
from 1 to 64. Each prescaler drives its counter, 
which decrements the value (1 to 256) that has 
been loaded into the counter. When the 
counter reaches the end of count, a timer 
interrupt request-IRQ4 (To) or IRQs (Tl)-is 
generated. 
The counters can be started, stopped, 
restarted to continue, or restarted from the 
initial value. The counters can also be pro- 
grammed to stop upon reaching zero (single- 
pass mode) or to automatically reload the 


The Z8671 allows six different interrupts from 
eight sources: the four Port 3 lines P30-P33, 
Serial In, Serial Out, and the two counter/ 
timers. These interrupts are both maskable and 
prioritized. The Interrupt Mask register global- 
ly or individually enables or disables the six 
interrupt requests. When more than one inter- 
rupt is pending, priorities are 'resolved by a 
programmable priority encoder that is con- 
trolled by the Interrupt Priority register. 
All Z8671 interrupts are vectored; however, 
the internal UART operates in a polling 
fashion. To accommodate a polled structure, 
any or all of the interrupt inputs can be mask- 
ed and the Interrupt Request register polled to 
determine which of the interrupt requests 
needs service. 
The BASIC/Debug Interpreter does not pro- 
cess interrupts. Interrupts are vectored 
\ 


initial value and continue counting (modulo-n 
continuous mode). The counters, but not the 
prescalers, can be read any time without 
disturbing their value or count mode. 
The clock source for Tl is user-definable; it 
can be either the internal microprocessor clock 
(4 MHz maximum for the 8 MHz device and 6 
MHz maximum for the 12 MHz device) divided 
by four, or an external signal input via Port 3. 
The Timer Mode register configures the exter- 
nal timer input as an external clock, a trigger 
input that can be retriggerable or non- 
retriggerable, or as a gate input for the inter- 
nal clock. The counter/timers can be pro- 
grammably cascaded by connecting the To out- 
put to the input of Tl. Port 3 line P36 also 
serves as a timer output (TOUT) through which 
To, TI or the internal clock can be output. 


through locations in internal ROM which point 
to addresses 1000-1011 (hex). To process inter- 
rupts, jump instructions can be entered to the 
interrupt handling routines at the appropriate 
addresses as shown in Table l. 


Address 
(hex) 


1000-1002 
1003-100S 
1006-1008 
1009-100B 
100C-lOOE 
100F-I011 


Contains Jump Instruction and 
Subroutine Address for: 


IRQO 
IRQl 
IRQ2 
IRQ3 
IRQ4 
IRQS 


Table 1. Interrupt Jump Instructions 


Clock 


Instruction 
Set 
Notation 


The on-chip oscillator has a high-gain, 
parallel-resonant amplifier for connection to a 
crystal or to any suitable external clock source 
(XTAL1 = Input, XTAL2 = Output). 
The crystal source is connected across 
XTALl and XTAL2, using the recommended 
capacitance (CL = 15 pF maximum) from each 


Addressing Modes. The following notation is used 
to describe the addressing modes and instruction 
operations as shown in the instruction summary. 


IRR 
Indirect register pair or indirect working-register 
pair address 
Irr 
Indirect working-register pair only 
X 
Indexed address 
DA 
Direct address 
RA 
Relative address 
1M 
R 


IR 


Ir 
RR 


Immediate 
Register or working-register address 
Working-register address only 
Indirect-register or indirect working-register 
address 
Indirect working-register address only 
Register pair or working register pair address 


Symbols. The folloWing symbols are used in 
describing the instruction set. 
dst 
Destination location or contents 
src 
Source location or contents 
cc 
Condition code (see list) 


@ 
Indirect address prefix 


SP 
Stack pointer (control registers 254-255) 


PC 
Program counter 


FLAGS Flag register (control register 252) 
RP 
Register pointer (control register 253) 


pin to ground. The specifications for the 
crystal are as follows: 
Il AT cut, parallel resonant 


CJ Fundamental type, 8/12 MHz maximum 


III Series resistance, Rs ::5 100 n 
IJ 8 MHz maximum for 28671 
lllI 12 MHz maximum for 28671-12 


IMR 
Interrupt mask register (control register 251) 


Assignment of a value is indicated by the symbol 


"-". For example, 
dst - 
dst + src 
indicates that the source data is added to the 
destination data and the result is stored in the 
destination location. The notation "addr(n)" is used 
to refer to bit "n" of a given location. For example, 
dst (7) 
refers to bit 7 of the destination operand. 


Flags. Control Register R252 contains the folloWing 
six flags: 


C 
Carry flag 
Z 
Zero flag 


S 
Sign flag 


V 
Overflow flag 
D 
DeCimal-adjust flag 
H 
Half-carry flag 


Affected flags are indicated by: 


0 
Cleared to zero 
Set to one 


." 
Set or cleared according to operation 
Unaffected 


X 
Undefined 
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Condition 
Codes 


Value 


1000 
0111 
1111 
0110 
1110 
1101 
0101 
0100 
1100 
0110 
1110 
1001 
0001 
1010 
0010 
1111 
0111 
1011 
0011 
0000 


Mnemonic 


C 
NC 
Z 
NZ 
PL 
MI 
OV 
NOV 
EO 
NE 
GE' 
LT 
GT 
LE 


UGE 
ULT 
UGT 
ULE 


Always true 
Carry 
No carry 
Zero 
Not zero 
Plus 
Minus 
Overflow 
No overflow 
Equal 
Not equal 


Meaning 


Greater than or equal 
Less than 
Greater than 
Less than or equal 
Unsigned greater than or equal 
Unsigned less than 
Unsigned greater than 
Unsigned less than or equal 
Never true 


C 
1 
C = a 
Z 
= 1 


Z = a 
S 
a 


S 
= 1 


V = 1 
V = a 
Z 
= 1 


Z 
= a 


Flags Set 


(S XOR V) = a 
(S XOR V) = 1 
[Z OR (S XOR V)) = a 
[Z OR (S XOR V)) = 1 
C=O 
C = 1 
(C = a AND Z = 0) 
(C OR Z) = I 


Instruction 
OPC 
CCF, 01, EI, IRET, NOP, 
RCF, RET, SCF 
Formats 
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dst 
OPC 
INC r 


One-Byte Instruction 


CLR, CPL, DA, DEC, 


'--......;;;=~--' OR 11 1 1 01 dst/src 1 ~~~~'~~:R~~~~R,POP, 


RRC, SRA, SWAP 


OPC 
I 
I--'-ds-'t---I OR 11 1 101 
dst 
JP, CALL (Indirect) 


ADC, ADD, AND, CP, 
LD, OR, SBC, SUB, 
TCM, TM, XOR 


1---=':---1 OR 11 1 1 01 
dst 


ADC, ADD, AND, CP, 
LD, OR, SBC, SUB, 
TCM, TM, XOR 


OPC 


VALUE 


dst 
1 OPC 


VALUE 


SRP 


ADC, ADD, AND, 
CP, OR, SBC, SUB, 
TCM, TM, XOR 


LD, LDE, LDEI, 
LDC, LOCI 


LD 


LD 


CJNZ. In 


Two-Byte Instruction 


Figure II. Instruction Formats 


LD 


LD 


JP 


CALL 


Three-Byte Instruction 
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Instruction 
Instruction 
Addr Mode 
Opcode Flags Affected 
Instruction 
Addr Mode 
Opcode Flags Affected 
Summary 
and Operation 
dst 
Byte 
and Operation 
dst 
Byte 
src 
(Hex) 
CZSVDH 
src 
(Hex) 
CZSVDH 


AOC dst,src 
(Note 1) 
10 
* 0 * 
LOE dst,src 
r 
Irr 
82 
------ 
dst - dst + src + C 
dst - 
src 
Irr 
92 


ADO dst,src 
(Note 1) 
00 
* * 0 * 
LOEI dst,src 
Ir 
Irr 
83 
------ 
dst - 
dst + src 
dst - 
src 
Irr 
Ir 
93 


ANO dst,src 
(Note 1) 
50 
0 
r - r + 1; rr - rr + 1 


dst - 
dst AND src 
NOP 
FF 


CALL dst 
DA 
06 
------ 
OR dst,src 
(Note 1) 
40 
* 0 - - 


Sp - 
SP - 2 
IRR 
04 
dst - dst OR src 


@SP - PC; PC - dst 
POP dst 
R 
50 
------ 
CCF 
EF 
* - - - - - 
dst - 
@SP 
IR 
51 
C - 
NOT C 
SP - 
SP + 1 


CLR dst 
R 
BO 
------ 
PUSH src 
R 
70 
------ 
dst - 
0 
IR 
Bl 
SP - SP-1; @SP- src 
IR 
71 


COM dst 
R 
60 
-**0-- 
RCF 
CF 
o - - - - - 
dst - 
NOT dst 
IR 
61 
C-O 


CP dst,src 
(Note 1) 
AD 
RET 
AF 
------ 
N 
dst - src 
PC - @ SP; SP - SP + 2 
CO 


DA dst 
R 
40 
* * * X - 
- 
RL dst 
EJLDJ I~ 
90 
****-- 
en 
...:I 
dst - 
OA dst 
IR 
41 
91 
... 


DEC dst 
R 
RLC dst ~I~ 


10 
3 
00 
-***-- 
dst - 
dst - 1 
IR 
01 
11 
~ 


RR dst 


4TI 4=3--J I~ 
EO 
****-- 
CI 


DECW dst 
RR 
80 
-***-- 
dst - 
dst - 1 
IR 
81 
El 


RRC dst L{i}:E3J R 
CO 
DI 
C 
, 
0 
IR 
Cl 
IMR (7) - 
0 
8F 
------ 
SBC dst,src 
(Note 1) 
3D 
* 1 * 


DJNZ r,dst 
RA 
rA 
------ 
dst - dst - src - C 


r - 
r - 1 
r=O-F 
SCF 
DF 
1 - 
- - - - 
if r *- 0 
C-l 


PC - 
PC + dst 
Range: + 127, -128 
SRA dst 4TI~I~ 
DO 
***0-- 


Dl 
EI 
9F 
------ 
SRP src 
1m 
31 
------ 
IMR (7) - 
1 
RP - 
src 
INC dst 
rE 
- * * * - - 
SUB dst,src 
(Note 1) 
20 
* * * * 1 * 
dst - 
dst + 1 
r=O-F 
dst - dst - src 
R 
20 


IR 
21 
SWAPdst~ R 
FO 
X * * X - 
- 


INCW dst 
AO 
IR 
Fl 
RR 
- 
* * * - - 
dst - 
dst + 
IR 
Al 
TCM dst,src 
(Note 1) 
60 
- 
* * 0 


IRET 
BF 
****** 


(NOT dst) AND src 


FLAGS - @SP; SP - SP + 1 
TM dst, src 
(Note 1) 
70 
- 
* * 0 
PC - 
@SP; SP - SP + 2; IMR(7) -1 
dst AND src 


JP cc,dst 
DA 
cD 
------ 
XOR dst,src 
(Note 1) 
BO 
- 
* * 0 - 
- 
if cc is true 
c=O-F 
dst - dst XOR src 
PC - 
dst 
IRR 
30 


JR cc,dst 
RA 
cB 
------ 
Note 1 
if cc is true, 
c=O-F 
PC - PC + dst 
These instructions have an identical set of adaressing 
Range: + 127, -128 
modes, which are encoded for brevity. The first opcode 


LO dst,src 
1m 
rC 
nibble is found in the instruction set table above. The 
r 
------ 
second nibble is expressed symbolically by a 0 in this 
dst - 
src 
r 
R 
r8 
R 
r9 
table, and its value is found in the following table to the 


r=O-F 
left of the applicable addressing mode pair. 


r 
X 
C7 
For example, the opcode of an ADC instruction using 
X 
r 
D7 
the addressing modes r (destination) and Ir (source) is 13. 
r 
Ir 
E3 
Ir 
r 
F3 
Addr Mode 
R 
R 
E4 
Lower 
R 
IR 
E5 
dst 
src 
Opcode Nibble 
R 
1m 
E6 
IR 
1m 
E7 
rn 
IR 
R 
F5 
Ir 
rn 


LDC dst,src 
r 
Irr 
C2 
------ 
R 
R 
m 
dst - 
src 
Irr 
D2 
R 
IR 
~ 
LOCI dst,src 
Ir. 
Irr 
C3 
------ 
R 
1M 
ffil 
dst - 
src 
Irr 
Ir 
03 


r - r + 1; rr - rr + 1 
IR 
1M 
(l] 
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Registers 
R240 SIO 
Serial I/O Register 
(FOH; Read/Write) 
I 0,1 0.1 051 0.1 0,1 0, I 0, I 
Do I 


'------SERIAL DATA (Do = LSB) 


R241 TMR 
Timer Mode Register 


(FIH; Read/Write) 
I 0,1 0,1 051 0.1 0,1 0, I 0, I 
Do I 


NOT USED = 00 .-J 
1 = LOAD To 


i~ g~i ~ ~~ 
0 = DISABLE To COUNT 


Tou,MODES J 
~~O 
= NO FUNCTION 


INTERNAL CLOCK OUT = 11 
1 = ENABLE To COUNT 


T 
MODES 
0 = NO FUNCTION 


EXTERNAL CLOCK IN~OT = 00 
1 = LOAD T, . 
GATE INPUT = 01 
0 = DISABLE T, COUNT 


(NON.R~~~~g~~~~:~~) = 10 
1 = ENABLE T, COUNT 


TRIGGER INPUT = 11 
(RETRIGGERABLE) 


R242 TI 
Counter Timer I Register 
(F2H; Read/Write) 
I 0,1 0,1 051 0.1 0,1 0, I 0, I 
Do I 


T, INITIAL VALUE (WHEN WRITTEN) 
'------(RANGE 1 256 DECIMAL 01 00 HEX) 
T, CURRENT VALUE (WHEN READ) 


R243 PREI 
Pres caler I Register 
(F3H; Write Only) 
I 0,10,1 051 0.1 0,1 0, I 0, I 
Do I 


l 


COO~Ni' ~~~ELE.PASS 


1 = T, MODULO.N 


CLOCK SOURCE 


1 
T, INTERNAL 
o 
T, EXTERNAL TIMING INPUT 
(T'N) MODE 


PRESCALER MODULO 
'-------(RANGE: 1·64 DECIMAL 
01·00 HEX) 


R244 TO 


Counter/Timer 0 Register 
(F4H; Read/Write) 
I 0,1 0.1 051 0.1 0,1 0, I 0, I 
Do I 


To INITIAL VALUE (WHEN WRITTEN) 
'------(RANGE: 1-256 DECIMAL 01-00 HEX) 
To CURRENT VALUE (WHEN READ) 


R245 PREO 


Prescaler 0 Register 
(F5H; Write Only) 


I~I~I~I~I~I~I~I~I 


~ 


COUNTMODE 
o = To SINGLE·PASS 
1 = To MODULO·N 


RESERVED (MUST BE 0) 


PRESCALER MODULO 
'-------(RANGE: 1-64 DECIMAL 
01-00 HEX) 


R246 P2M 
Port 2 Mode Register 
(F6H; Write Only) 
I 0,1 0,1 051 0.1 0,1 0, I 0, I Do I 


P2o-P2, 110 DEFINITION 
'------ 0 DEFINES BIT AS OUTPUT 


1 DEFINES BIT AS INPUT 


R247 P3M 
Port 3 Mode Register 
(F7H; Write Only) 


I~I~I~I~I~I~I~I~I 


~~~ 


O PORT 2 PULL·UPS OPEN DRAIN 
1 PORT 2 PULL·UPS ACTIVE 


RESERVED (MUST BE 0) 
o P32 = INPUT 
P3s = OUTPUT 


1 P32'; DAVO/RDYO P3s = RDYO/1lAVO 


o 0 
P3, = INPUT 
P34 = OUTPUT 


~ ~} P3, = INPUT 
P34 = OM 


1 1 
P3, = DAV1/RDYI P34 = RDY1/DAVl 


'--------~ ~~: ~ ~~vU~~6~1 ~~: ~ ~g~~/~~~r) 
'--------- ~ ~~~ ~ kN~~IL IN 
~~~ ~ ~~~:;'~T OUT 


'----------~ 
~~=:i~ g~F 


Figure 12. Co~trol Registers 
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Registers 
(Continued) 
R248 POIM 
Port 0 and I Mode Register 
(F8H; Write Only) 


OUTPUT; 00 
INPUT; 01 
A,rA15 ; IX 


I 0,1 0,1 051 0, I 0,1 D,TD,lO:J 


L 
00; OUTPUT 
01 ; INPIJT 
IX; A,-A" 


PO,-PO, MODE~ 


EXTERNAL MEMORY TIMING 
NORMAL; 0 
- 


EXTENDED; 1 ~ 


-r- POo-PO, MODE 


STACK SELECTION 
o ; EXTERNAL 
. 
1 ; INTEf>NAL 


PIa-PI, MODE 
00 = BYTE OUTPUT 
01 ; BYTE INPUT 
10 ; ADo-AD, 
11 ; HIGH·IMPEDANCE ADo-Ail7, 
AS, OS, R/W, As-A", A'2-A'5 
IF SELECTED 


R2491PR 


Interrupt Priority Register 
(F9H; Write Only) 


I~I~I~I~I~I~I~I~I 


RESERVED (MUST BE 0):J I 


IR03, IROS PRIORITY (GROUP A) 
o = IROS > IR03 
1 = IR03 > IROS 


IROO, IR02 PRIORITY (GROUP B) 
o = IR02 > IROO _____ 
---1 


1 = IROO > IR02 


IR01, IR04 PRIORITY (GROUP C) 
o = IROI > IR04 --------' 
1 = IR04 > IROI 


INTERRUPT GROUP PRIORITY 
RESERVED = 000 
C > A > B = 001 
A> C > C = 010 
A> C > 8 = 011 
B > C > A = 100 
C> B > A = 101 
B > A > C = 110 
RESERVED = 111 


R250 IRQ 
Interrupt Reque!::t Register 


(FAH; Read/Write) 


I~I~I~I~I~I~I~I~I 


RESERVED (MUST'BE O)=:r- 
c== 
IROO 
IROI 
IR02 
IR03 
IR04 
IROS 


R2511MR 


Interrupt Mask Register 
(FBH; Read/Write) 


I~I~I~I~I~I~I~I~I 


P32 INPUT (Do = IROO) 
P33 INPUT 
P3, IN?LiT 
P30 INPUT, SERIAL INPUT 
To, SERIAL OUTPUT 
T, 


II 
c== 1 ENABLES IRaQ-lAOS 


(Do = IROC) 
L--_______ RESERVED (MUST BE 0) 
'----------1 ENADLES INTERRUPTS 


REGISTER 
FO!NTCR 


!a2S2 fLAGS 
FICl:g' Rcgi.Gt~T 


(FCH; Read/Write) 
I D,I D,I D51 D, I 0,1 D,I 0, I 
Do I 


~~~ 


LUSERFLAGFI 
LUSER FLAG F2 


HALF CARRY FLAG 


DECIMAL ADJUST FLAG 


OVERFLOW FLAG 


SIGN FLAG 


ZERO FLAG 


L....-------CARRy FLAG 


R253 RP 
RGgiztcr Pointer 
(FDH; Read/Write) 
I 0,1 0,1 051 0, I 0,1 0,1 0, I 
Do I 


{:~g)J 


C=DON'T CARE 


R254 SPH 
Stc.:c!: Pointer 


(FEH; Read/Write) 


I~I~I~I~I~I~I~I~I 


L--____ STACK POINTER UPPER 
BYTE (SP.-SP15) 


R2558PL 
Stack Point~r 


(FFH; Read/Write) 
l!d 061 05 1 0.1 03 1 0,1 0, I 
Do I 


LI ____ ~~~~~s~~~~J~R LOWER 


Figure 12. Control Registers (Continued) 
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Z8671 
Opcode 
Map 


o 


2 


3 


" 


5 


M 
6 


III a 


GI :a 
7 
:9 
:z; .. 
III 
0. 
8 
0. 
=- 


9 


A 


B 


C 


0 


E 


F 


o 


6,5 
DEC 
Rl 


6,5 
RLC 
Rl 


6,5 
INC 
Rl 


8,0 
IP 
IRRl 


8,5 
OA 
Rl 


10,5 
POP 
Rl 


6,5 
COM 


Rl 


10/12,1 
PUSH 
R:z 


10,5 
OECW 


RRl 


6,5 
RL 
Rl 


10,5 
INCW 
RRl 


6,5 
CLR 
Rl 


6,5 
RRC 
Rl 


6,5 
SRA 
Rl 


6,5 
RR 
Rl 


8,5 
SWAP 


Rl 


6,5 
DEC 
IRl 


6,5 
RLC 
IRl 


6,5 
INC 
IRl 


6,1 
SRP 


1M 


8,5 
OA 
IRl 


10,5 
POP 
IRl 


6,5 
COM 


IRl 


12/14,1 
PUSH 
IR:z 


10,5 
OECW 


IRl 
6,5 
RL 
IRl 


10,5 
INCW 
IRl 


6,5 
CLR 
IRl 


6,5 
RRC 
IRl 


6,5 
SRA 
IRl 


6,5 
RR 
IRl 


8,5 
SWAP 


IRl 


2 
3 


6,5 
6,5 


ADD 
ADD 


rl, r2 
fl,Ir2 


6,5 
6,5 


ADC 
ADC 


rl, r2 
r 1, Ir2 


6,5 
6,5 
SUB 
SUB 
rl, r2 
rl,Ir2 


6,5 
6,5 
SBC 
SBC 
rl, r2 
rl,lr:z 


6,5 
6,5 
OR 
OR 
rl, r:z 
rl,lr:z 


6,5 
6,5 
ANO 
ANO 
rl, r:z 
rl,lr:z 


6,5 
6,5 


TCM 
TCM 


rl, r:z 
fl,lr:z 


6,5 
6,5 


TM 
TM 


rl, r2 
rl,lr:z 


12,0 
18,0 
LOE 
LOEI 
rl,Irr2 Ir 1, Irr2 


12,0 
18,0 
LOE 
LOEI 
r2,Irfl Ir2,Irrl 


6,5 
6,5 


CP 
CP 


rl, r2 
rl, Ir2 


6,5 
6,5 


XOR 
XOR 


rl, r2 
rl,Ir2 


12,0 
18,0 
LOC 
LOCI 
rl, Irr2 Irl,Irr2 


12,0 
18,0 
LOC 
LOCI 
r2,Irrl Ir2,Irrl 


6,5 
LO 
rl,IR2 


6,5 
to 
Irl, r2 


Lower Nibble (Hex) 


" 


5 
6 
7 
8 
9 
A 
B 
C 
o 
E 
F 


10,5 
10,5 
10,5 
10,5 
6,5 
6,5 
12/10,5 
12/10,0 
6,5 
12/10,0 
6,5 


ADD 
ADD 
ADD 
ADD 
LO 
LO 
OJNZ 
JR 
LO 
JP 
INC 


R2,Rl 
IR2,Rl 
Rl,lM 
IRl,lM 
fl,R2 
r2, Rl 
fl,RA 
cc,RA 
ll,IM 
cc,DA 
fl 
10,5 
10,5 
10,5 
10,5 
r--- 


ADC 
ADC 
ADC 
ADC 


R2,Rl 
IR2,Rl 
Rl,lM 
IR1,IM 


10,5 
10,5 
10,5 
10,5 
r--- 
SUB 
SUB 
SUB 
SUB 
R2,Rl 
IR2,Rl 
Rl,lM 
IRl,lM 


10,5 
10,5 
10,5 
10,5 
r--- 
SBC 
SBC 
SBC 
SBC 
R2,Rl 
IR:z,Rl 
Rl,lM 
IR1,IM 


10,5 
10,5 
10,5 
10,5 
r--- 


OR 
OR 
OR 
OR 
R2,Rl 
IR2,Rl 
Rl,lM 
IR1,IM 


10,5 
10,5 
10,5 
10,5 
r--- 


ANO 
ANO 
ANO 
ANO 
R:z,Rl 
IR:z,Rl 
Rl,lM 
IR1,IM 


10,5 
10,5 
10,5 
10,5 
r--- 


TCM 
TCM 
TCM 
TCM 


R:z,Rl 
IR2,Rl 
Rl,lM 
IRl,lM 


10,5 
10,5 
10,5 
10,5 
r--- 


TM 
TM 
TM 
TM 


R2,Rl 
IR2,Rl 
Rl,lM 
IRl,lM 
r--- 
6,1 
DI 


r--- 
6,1 
EI 


r--- 
10,5 
10,5 
10,5 
10,5 
14,0 
CP 
CP 
CP 
CP 
RET 
R2,Rl 
IR2,Rl 
Rl,lM 
IRl,lM 


10,5 
10,5 
10,5 
~ 
10,5 
16,0 
XOR 
XOR 
XOR 
XOR 
IRET 
R2,Rl 
IR2,Rl 
Rl,lM 
IR1,IM 
---- 
10,5 
6,5 
LO 
RCF 
fl, x, R2 
- 
20,0 
20,0 
10,5 
6,5 
CALL* 
CALL 
LO 
SCF 
IRRl 
DA 
r2, x, Rl 


10,5 
r--- 
10,5 
10,5 
10,5 
6,5 
LO 
LO 
LD 
LD 
CCF 
R2,Rl 
IR2,Rl 
Rl,lM 
IRl,lM 
r--- 
10,5 
6,0 
to 
NOP 
R2,IRl 
1 


" 


~ '" 
"I \.. 


By~es per 
vP 
vP 
~--------~~~.-----------'~ ~ 
~ 


Instruction 
2 
3 


Lower 
Opcode 
Nibble 


Execution 
+ 
Pipeline 
Cycles 
Cycles. 


Upper 


Opcode --. A 
Mnemonic 
Nibble 


First 
Second 


Operand 
Operand 


·2-byte instruction; fetch cycle appears as a 3-byte instruction 
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2 


Legend: 
R = a-Bit Address 
r = 4-Bit Address 
RI or n = Dst Address 
R2 or r2 = Src Address 


Sequence: 


3 


Opcode, First Operand, Second Operand 


Note: The blank areas are not defined. 


Absolute 
Maximum 
Ratings 


Standard 
Test 
Conditions 


DC 
Character- 
istics 


8085-0313,2194-010 


Voltages on all pins 
with respect to GND .......... -0.3 V to + 7.0 V 
Operating Ambient 
Temperature ........ See Ordering Information 


Storage Temperature ........ -65°C to + 150°C 


The characteristics below apply for the 
following standard. test conditions, unless 
otherwise noted. All voltages are referenced to 
GND. Positive current flows into the reference 
pin. Standard conditions are as follows: 


+5V 


2.1K 


Stresses greater than those listed under Absolute Maxi- 
mum Ratings may cause permanent damage to the device. 
This is a stress rating only; operation of the device at any 
condition above those indicated in the operational sections 
of these specifications is not implied. Exposure to absolute 
maximum rating conditions for extended periods may affect 
device reliability. 


[J +4.75 V :::; Vee:::; +5.25 V 
[] GND = 0 V 


IJ O°C :::; TA :::; +70°C 


+5V 


18K 


+5V 
+5V 


1.Sk 
1.5k 


74LS04 
74LS04 


CLI~CK ---I>·o---+~>-l~I><>--+--'I-- XTAL2 


I I CL = lSpF MAX 


'------.-- XTAL 1 


I 
I 1 
CL = lSpF MAX 


Figure 13. Test Load 1 
Figure 14. Test Load 2 
Figure 15. TTL External Clock Interface Circuit 
(Both the clock and its complement <:Ire required) 


Symbol 
Parameter 
Min 
Max 
Unit 
Condition 


VeH 
Clock Input High Voltage 
3.8 
Vee 
V 
Driven by External Clock Generator 


VeL 
Clock Input Low Voltage 
-0.3 
0.8 
V 
Driven by External Clock Generator 


VIH 
Input High Voltage 
2.0 
Vee 
v 


VIL 
Input Low Voltage 
-0.3 
0.8 
V 


VRH 
Reset Input High Voltage 
3.8 
Vee 
V 


VRL 
Reset Input Low Voltage 
-0.3 
0.8 
V 


VOH 
Output High Voltage 
2.4 
V 
IOH = -250 p.A 


VOL 
Output Low Voltage 
0.4 
V 
IOL ;", +2.0 rnA 


ILL 
Input Leakage 
-10 
10 
itA 
o V~ VIN ~ +5.25 V 


IOL 
Output Leakage 
-10 
10 
itA 
o V~ VIN ~ +5.25 V 


1m 
Reset Input Current 
-50 
itA 
Vee = +5.25 V, VRL = 0 V 


Icc 
Vee Supply Current 
180 
rnA 


IMM 
VMM Supply Current 
10 
rnA 
Power Down Mode 


VMM 
Backup Supply Voltage 
3 
Vee 
V 
Power Down 
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External 110 
R1W 
or Memory 
Read/Write 


PORT 0, 


DM 


16 


PORT 1 


is 
CD 


CD 
os 


(READ) 


PORT 1 
Ao-A7 
00-07 OUT 


os 
(WRITE) 


Figure 15. External I/O or Memory Read/Write 


Z8671 
Z8671-12 
No. 
Symbol 
Parameter 
Min 
Max 
Min 
Max 
Notes*t 


TdA(AS) 
Address Valid to AS t Delay 
50 
35 
1,2,3 


2 
TdAS(A) 
AS I to Address Float Delay 
70 
45 
1,2,3 


3 
TdAS(DR) 
AS I to Read Data Required Valid 
360 
220 
1,2,3,4 


4 
TwAS 
AS Low Width 
80 
55 
1,2,3 


5 
TdAz(DS) 
Address Float to DS I 
0 
0 


6-TwDSR 
DS (Read) Low Width 
250 
185 
1,2,3,4 


7 
TwDSW 
DS (Write) Low Width 
160 
110 
1,2,3,4 


8 
TdDSR(DR) 
DS I to Read Data Required Valid 
200 
130 
1,2,3,4 


9 
ThDR(DS) 
Read Data to DS t Hold Time 
0 
0 
1 


10 
TdDS(A) 
DS t to Address Active Delay 
70 
45 
1,2,3 


11 
TdDS(AS) 
DS t to AS I Delay 
70 
55 
1,2,3 
12-TdR/W(AS)--R/W Valid to AS I Delay 
50 
30 
1,2,3 


13 
TdDS(R/W) 
DS I to R/W Not Valid 
60 
35 
1,2,3 


14 
TdDW(DSW) 
Write Data Valid to DS (Write) I Delay 
50 
35 
1,2,3 


15 
TdDS(DW) 
DS t to Write Data Not Valid Delay 
70 
45 
1,2,3 


16 
TdA(DR) 
Address Valid to Read Data Required Valid 
410 
255 
1,2,3,4 


17 
TdAS(DS) 
AS I to DS I Delay 
80 
55 
1,2,3 


NOTES: 
1. Test Load 1 
5. All timing references use 2.0 V'for a logic "1" and 0.8 V for a logic "0". 


2. Timing numbers given are for minimum TpC. 
• All units in nanoseconds (ns). 
3. Also see clock cycle time dependent characteristics table. 
t All timings are preliminary and subject to change. 
4. When using extended memory timing add 2 TpC. 
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2194·011 


Additional 
Timing 


No. 
Symbol 


1 
TpC 


2 
TrC,TfC 


3 
TwC 


4 
TwTinL 
5-TwTinH 


6 
TpTin 


7 
TrTin, TfTin 


8a 
TwIL 


8b 
TwIL 


9 
TwIH' 


NOTES: 


Figure 16. Additional Timing 


Z8671 
Z8671-12 


Parameter 
Min 
Max 
Min 
Max 


Input Clock Period 
125 
1000 
83 
1000 


Clock Input Rise And Fall Times 
25 
15 
Input Clock Width 
37 
26 
Timer Input Low Width 
100 
70 


Timer Input High Width 
3TpC 
3TpC 
Timer Input Period 
8TpC 
8TpC 
Timer Input Rise And Fall Times 
100 
100 


Interrupt Request Input Low Time 
100 
70 


Interrupt Request Input Low Time 
3TpC 
3TpC 
Interrupt Request Input High Time 
3TpC 
3TpC 


1. Clock timing references uses 3.8 V for a logic "1" and 0.8 V for 
3. Interrupt request via Port 3 (P31-P33)' 


a logic "0". 
4. Interrupt request via Port 3 (P30)' 


2. Timing reference uses 2.0 V for a logic "I" and 0.8 V for 
• Units in nanoseconds (ns). 
a logic "0". 


Memory Port 
Timing 


No. 
Symbol 


TdA(DI) 
2 
ThDI(A) 


NOTES: 


t All timings are preliminary and subject to change. 


AO-A10 ~~ 
____ -:: ____ 
-:-_A_DD_R_ES_S_V_A_LlD __________ .JJU 


_-----J_ 
1--- _CD 
----"'~l 
T~l~ 


Do-D7 
DON'T CARE 
X 
DATA IN VALID 
K- 


Figure 17. Memory Port Timing 


Parameter 


Address Valid to Data Input Delay 
Data In Hold Time 


Min 


o 


Z8671 


Max 


460 


Z8671-12 


Min 
Max 


320 


o 


Notes*t 


2 


2 
2 


2 
2,3 


2,4 
2,3 


Notes*t 


1,2 


1 


1. Test Load 2 
2. This is a Clock-Cycle-Dependent parameter. For clock frequen- 
cies other than the maximum, use the following formula: 


• Units are nanoseconds unless otherwise specified; timings are 
preliminary and subject to change. 


Z8671 = 5 TpC - 
165 
Z8671-12 = 5 TpC - 95 


2194-012, 2037-019 
539 


II 
en 
--:a ... 
ac 
n 
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Handshake 
Timing 


No. 
Symbol 


2 


TsDI(DAV) 


ThDI(DAV) 


DA::~:, ______ ~ 
___ . :"""":_ ~ ....._----- 


RDY 


(OUTPUT) 


DATA OUT 


Figure 17a. InputHandshake 
r- 
DATA OUT VALID 
--~~------------------ 
1~-CD}----~-~ 


DAV 


(OUTPUT) 


RDY 
(INPUT) 


Parameter 


Data In Setup Time 


Data In Hold Time 


Figure 17b. Output Handshake 


Z8671 


Min 
Max 


0 


230 


Z8671-12 


Min 
Max 


0 


160 


3 
TwDAV 
Data Available Width 
175 
120 


Notes*t 


4 
TdDAVIf(RDY) 
DAV I Input to RDY I Delay 
175 


5-TdDAVOf(RDY)-DAV I Output to RDY I Delay--------- 0 
0 


120 . 
1,2 


-------1,3 


6 
TdDAVIr(RDY) 
DAV I Input to RDY I Delay 


7 


8 


9 


NOTES: 


TdDAVOrRDY) 


TdDO(DAV) 


TdRDY(DAV) 


I. Test load 1 
2. Input handshake 
3. Output handshake 


DA V I Output to RDY t Delay. 


Data Out to DA V I Delay 


Rdy I Input to DA V 1 Delay 


4. All timing regerences use 2.0 V for a logic "I" and 0.8 V for 
a logic "0". 


Clock- 
Cycle-Time- 
Number 
Symbol 
Dependent 
TdA(AS) 
Characteristics 
2 
TdAS(A) 


3 
TdAS(DR) 


4 
TwAS 


6 
TwDSR 


7 
TwDSW 


8 
TdDSR(DR) 


10 
Td(DS)A 


11 
TdDS(AS) 


12 
TdR/W(AS) 


13 
TdDS(R/W) 


14 
TdDW(DSW) 


15 
TdDS(DW) 


16 
TdA(DR) 


17 
TdAS(DS) 


• Add 2TpC when using extended memory timing 
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Z8671 


Equation 


TpC-75 


TpC-55 


4TpC-140* 


TpC-45 


3TpC-125* 


2TpC-90* 


3TpC-175* 


TpC-55 


TpC-55 


TpC-75 


TpC-65 


TpC-75 


TpC-55 


5TpC-215* 


TpC-45 


175 
120 


0 
0 


50 
30 


0 
200 
0 
140 


• Units in nanoseconds (ns). 
t All timings are preliminary and subject to change. 


Z8671-12 
Equation 


TpC-50 


TpC-40 


4TpC-II0* 


TpC-30 


3TpC-65* 


2TpC-55*. 


3TpC-120* 


TpC-40 


TpC~30 


TpC-55 


TpC-50 


TpC-50 


TpC-40 


5TpC-160* 


TpC-30 


1,2 


1,3 


2194-013 


Ordering 
Product 
P~ckagc/ 
Product 
Package/ 


Information 
Number 
Temp 
Speed 
Description 
Number 
Temp 
Speed 
Description 


Z8671 
PE 
8.0 MHz 
Z8 MCU with 
Z8671-12 
' PE 
12.0 MHZ 
Z8 MCU with 
BASIC/Debug 
BASIC/Debug 
Interpreter 
Interpreter 
(40-pin) 
(40-pin) 


Z8671 
PS 
8.0 MHz 
Same as above 
Z8671-12 
PS 
12.0 MHz 
Same as above 


Z8671 
CE 
8.0 MHz 
Same as above 
Z8671-12 
CE 
12.0 MHz 
Same as above 


Z8671 
CS 
8.0 MHz 
Same as above 
Z8671-12 
CS 
12.0 MHz 
Same as above 


NOTES: C = Ceramic; P = Plastic; E = -40°C to +85°C, S = O°C to +70°C. 
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Zilog 


Features 


General 
. Description 


2194-001, 002 


III Complete microcomputer, 24 I/O lines, and 
up to 64K bytes of addressable external 
space each for program and data memory. 


El 143-byte register file, including 124 


general-pwpose registers, three I/O port 
registers, and 16 status and control 
registers. 


II Vectored, priority interrupts for I/O, 


counter/timers, and UART. 


13 On-chip oscillator that accepts crystal or 
external clock drive. 


The 28681and 28682 are ROMless versions of 
the 28 single-chip microcomputer. The 28682 
is usually more cost effective. These products 
differ only slightly and can be used inter- 
changeably with proper system design to pro- 
vide maximum flexibility in meeting price and 
delivery needs .. The 28681182 offers all the 
outstanding features of the '28 family archi- 
tecture except an on-chip program ROM. Use 
of external memory rather than a prepro- 
grammed ROM enables this 28 microcomputer 


TlM~=g 
R/W 
1 


_ 
RESET 
+5V 


GND 


XTALl 


XTAL2 


P20 


CONTROL 
os 
. 
AS 


PORTO 
(NIBBLE 


PO. 


PO, 


P02 


P2, 


PRO~/~A~RMAA8~;~: _ 
PO. 
P2. 


PORT 1 
(BYTE 
PROGRAMMABLE) 
ADo-AD, 


POs Z8681/82 P2s 


POa 
MCU 
P2a 


PO, 
P2, 


Pl 0 
P30 
Pl, 
P3, 


P1 2 
P32 
Pl 3 
P33 
. Pl. 
P3, 


Pls 
P3s 


P1 6 
P36 


Pl, 
P3, 


Figure 1. Pin Functions 


PORT 2 
(BIT PRO· 
GRAMMABLE) 
I/O 


PORT 3 
(FOUR INPUT; 
FOUR OUTPUT) 
SERIAL AND 
PARALLEL I/O 
AND CONTROL 


Z8® 18681/82 
ROMless 
Microcomputer 


Product 
Specification 


September 1983 


II Full-duplex UART and two programmable 
8-bit counter/timers, each with a 6-bit pro- 
grammable prescaler. 


CI Register Pointer so that short, fast instruc- 
tions can access anyone of the nine 
working-register groups. 


m Low-power standby option that retains 
contents of general-purpose registers. 


II Single + 5 V power supply-all I/O pins 
TTL compatible. 


Ell Available in 8 and 12 MHz versions. 


to be used in low volume applications or where 
code flexibility is required. 
The 28681182 «:an provide up to 16 output 
address lines, thus permitting an address 
space of up to 64K by tea of data or program 
memory. Eight address outputs (ADo-AD7) are 
provided by a multiplexed, 8-bit, Address/Data 
bus. The remaining 8 bits can be provided by 
the software configuration of Port 0 to output 
address bits Aa-AIS. 


+5V 
P3a 


XTAL2 
P3, . 


XTALl 
P2, 


P3, 
P2a 
P30 
P2s 


RESET 
P2. 


R/W 
P23 


os 
P22 


~ 
P2, 


P3s 
P20 


GND 
P33 
P32 
P3. 


POo 
Pl, 


po, 
P1 6 


P02 
Pls 
P03 
Pl. 


PO. 
P1 3 


POs 
P1 2 


POa 
Pl, 


PO, 
Pl. 


Figure 2. Pin Assignments 
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General 
Description 
(Continued) 


Architecture 


Pin 
Description 
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Available address space can be doubled (up 
to 128K bytes for the 28681 and 124K bytes for 
the 28682) by programming bit 4 of Port 3 
(P34) to act as a data memory select output 
(DM). The two states of DM together with the 
16 address outputs can define separate data 
and memory address spaces of up to 
64K/62Kbytes each. 
There are 143 bytes of RAM located on-chip 
and organized as a register file of 124 general- 
purpose registers, 16 control and status 


28681182 architecture is characterized by a 
flexible I/O scheme, an efficient register and 
address space structure and a number of 
ancillary features that are helpful in many 
applications. 
Microcomputer applications demand power- 
ful I/O capabilities. The 28681182 fulfills,this 
with 24 pins available for input and output. 
These lines are grouped into three ports of 
eight lines each and are configurable under 
software control to provide timing, status 
signals, serial or parallel I/O with or without 
handshake, and an Address bus for interfacing 
external memory. 
Three basic address spaces are available: 


OUTPUT 
INPUT 
Vee 
GND 


registers, and three I/O port registers. This 
register file can be divided into nine groups of 
16 working registers each. Configuring the 
register file in this manner allows the use of 
short format instructions; in addition, any of 
the individual registers may be accessed 
directly. 
The pin functions and the pin assignments of 
the 28681182 40-pin package are illustrated in 
Figures 1 and 2, respectively. 


program memory, data memory and the 
register file (internal). The 143-byte random- 
access register file is composed of 124 general- 
purpose registers, three I/O port registers, and 
16 control and status registers. 
To unburden the program from coping with 
real-time problems such as serial data com- 
munication and counting/timing, an asynchro- 
nous receiver/transmitter (UART) and two 
counter/timers with a large number of user- 
selectable modes are offered on-chip. Hard- 
ware support for the UART is minimized' 


b~cause one of the on-chip timers supplies the 
bit rate. Figure 3 shows the 28681182 block 
diagram. 


M/L.---!-! _\~--'---1 


UART 


[ 
PORTO 


lllllltl 


110 
(BIT PROGRAMMABLE) 


ADDRESS OR 110 
(NIBBLE PROGRAMMABLE) 
, 


ADDRESSIDATA OR 110 
(BYTE PROGRAMMABLE) 


# 


Z·BUS WHEN USED AS 
ADDRESSIOATA BUS 


Figure 3. Functional Block Diagram 


AS. Address Strobe (output, active Low). 
Address Strobe is pulsed once at the -begin- 
ning of each machine cycle. Addresses output 
via Port 1 for all external program or data 
memory transfers are valid at the trailing edge 
of AS. 


OS. Data Strobe (output, active Low). Data 
Strobe is activated once for each external 
memory transfer. 


POo-P~. P2o-P27. P30-P37' I/O Port Lines 
(inpuVoutputs, TTL-compatible). These 24 
lines are divided into three 8-bit I/O ports that 
can be configured under program control for 
I/O or external memory interfpce (Figure 3). 


P1o-PI7. Address/Data Port (bidirectional). 
Multiplexed address (Ao-A7) and data (Do-D7) 
lines used to interface with program and data 
memory. 


2194-003 


Pin 
Description 
(Continued) 


Summary of 
Z8681 and 
Z8682 
Differences 


Address 
Spaces 


2194-004 


RESET.* Reset (input, active Low). RESET ini- 
tializes the 28681182. When RESET is deacti- 
vated, program execution begins from pro- 
gram location OOOCH for the 28681 and 0812H 
for the 28682. 
R/W. Read/Write (output). RlW is Low when 


Feature 


Address' of first instruc- 
tion executed after Reset 


Addressable memory 
space 


Address of interrupt 
vectors 


Z8681 


12 


0-64K 


0-11 


the 28681182 is writing to external program or 
data memory. 
XTALL XTAL2. Crystall, Crystal 2 (time-base 
input and output). These pins connect a 
parallel-resonant crystal to the on-chip clock 
oscillator and buffer. 


Z8682 


2066 


2K-64K 


2048-2065 


Reset input high voltage 


Port 0 configuration 
after Reset 


TTL levels' 
7.35-8.0 V 


External memory timing 
start-up configurations 


J~'errupt vectors 


Interrupt response time 


'8.0 V VIN max 


Input, float after reset. 
Can be programmed as 
Address bits. 


Extended Timing 


2 byte vectors point 
directly to service 
routines. 


26JLsec 


Output, configured as 
Address bits A8-A15' 


Normal Timing 


2 byte vectors in internal 
ROM point to 3 byte Jump 
instructions, which point 
to service routines. 


36JLsec 


Program Memory.* The 28681182 addresses 
64K/62K bytes of external program memory 
space (Figure 4). 


For the 28681, the first 12 bytes of program 
memory are reserved for the interrupt vectors. 
These locations contain six 16-bit vectors that 


LOCATION OF FIRST 


BYTE OF INSTRUCTION 


EXECUTED AFTER 


RESET (Za681) 


INTERRUPT 
VECTOR 
(LOWER BYTE) 


INTERRUPT 
VECTOR 


(UPPER BYTE) 


5536 


- 


Z8681 
Z8682 


PROGRAM 
MEMORY 


PROGRAM 
MEMORY r----- 
,# 
f= 
IROS = 


f= 
IR04 = 


f= 
IR03 = 


f= 
IR02 = 


~ IROl 
-- 
= 


IROO = 


NOT 
ADDRESSABLE 
r----- 
r... 
I- 
IR05 
- 


I- 
IR04 
- 


I- 
IR03 
- 


~ 
IR02 
- 


I- 
IROl 
- 


I- 
IROO 
- 


6553 


/ 


(812H 
(811 H 


..,.- 


(800H 
2047 


12 
11 
10 
9 
8 


LOCATION OF FIRST' 
BYTE OF INSTRUCTION 
EXECUTED AFTER 
RESET (Z8682) 


) 2066 
) 2065 


3 BYTE INTERRUPT 
JUMP INSTRUCTIONS 


) 2048 


7 
6 
5 


2 BYTE 
..,.-INTERRUPT 
VECTORS 


4 
3 
2 
1 
0 


Figure 4. Z8681/82 Program Memory Map 


'This feature differs in the Z8681 and Z8682 
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correspond to the six available interrupts. Pro- 
gram execution begins at location OOOCH after 
a reset. 
The 28682 has six 24-bit interrupt vectors 
beginning at address 0800H. The vectors con- 
sist of Jump Absolute instructions. After a 
reset, program execution begins at location 
0812H 'for the 28682. 
Data Memory. * The 28681182 can address 
64K/62K bytes of external data memory. Exter- 
nal data memory may be included with or 
separated from the external program. memory 
space. DM, an optional I/O function that can 
be programmed to appear on pin P34, is used 
to distinguish between data and program 
memory space. 
Register File. The 143-byte register file 
includes three I/O port registers (RO, R2, R3), 
124 general-purpose registers (R4-RI27) and 
16 control and status registers (R240-R255). 


LOCATION 


255 
254 


253 


252 


251 


250 


249 
248 


247 


246 


245 


244 


243 


242 


241 


240 


127 


STACK POINTER (BITS 7-0) 


STACK POINTER (BITS 15-8) 


REGISTER POINTER 


PROGRAM CONTROL FLAGS 


INTERRUPT MASK REGISTER 


INTERRUPT REOUEST REGISTER 


INTERRUPT PRIORITY REGISTER 


PORTS 0-1 MODE 


PORT 3 MODE 


PORT 2 MODE 


TO PRESCALER 


TIMER/COUNTER 0 


Tl PRESCALER 


TIMER/COUNTER 1 


TIMER MODE 


SERIAL I/O 


NOT 
IMPLEMENTED 


GENERAL·PURPOSE 
REGISTERS 


PORT 3 


PORT 2 


PORT 0 


Figure 5. The Register File 


"This feature differs in the 28681 and 28682 


IDENTIFIERS 


SPL 


SPH 


RP 


FLAGS 


IMR 


IRO 


IPR 


P01M 


P3M 


P2M 


PREO 


TO 


PREl 


T1 


TMR 


SIO 


P3 


P2 


PO 


These registers are assigned the address loca- 
tions shown in Figure 5. 
28681182 instructions can access registers 
directly or indirectly with an 8-bit address 
field. This also allows short 4-bit register ad- 
dressing using the Register Pointer (one of the 
control registers). In the 4-bit mode, the 
register file is divided into nine working- 
register groups, each occupying 16 contiguous 
locations (Figure 5). The Register Pointer 
addresses the starting location of the active 
working-register group (Figure 6). 


Stacks. Either the internal register file or the 
external data memory can be used for the 
stack. A 16-bit Stack Pointer (R254 and R255) 
is used for the external stack, which can reside 
anywhere in data memory. An 8-bit Stack 
Pointer (R255) is used for the internal stack 
that resides within the 124 general-purpose 
registers (R4-R127). 


r--_ 
~-;-;:( ==1------.255 
~ 1--_~:""';'_L-~~--:---I253 


...... ----------'240 


The upper nibble of the register ilia address 
provided by the register pointer specifies 
the active working-register group. 


- ... 


-... 


-... 


-... ( 


SPECIFIED WORKING· 
REGISTER GROUP 
{ 


-... { 


- ... { 


1 27 


~I- 


1 


The lower 
nibble of 
the register 
file address 
provided by 
the Instruction 
points to the 
specified 
register. 


-... { -------------.- 3 
I/O PORTS 
0 


Figure 6. The Register Pointer 


2194- 005, 006 


Serial 
Input/ 
Output 


Counter/ 
Timers 


I/O Ports 


2037·009 


Port 3 lines P30 and P37 can be programmed 
as serial I/O lines for full-duplex serial asyn- 
chronous receiver/transmitter operation. The 
bit rate is controlled by Counter/Timer 0, with 
a maximum rate of 62.5K bits/second at 8 MHz 
and 93.75K bits/second at 12 MHz. 
The 28681182 automatically adds a start bit 
and two stop bits to transmitted data (Figure 
7). Odd parity is also available as an option. 
Eight data bits are always transmitted, 


Isp I SP I 071 
Dsl 051 0.1 031 021 0, I Do I ST I 


1 


LSTART BIT 
'------EIGHT DATA BITS 


TWO STOP BITS 


Transmitted Data 
(No Parity) 


, I SP I 
SP I P , Dsl 05' 0.1 031 021 0, I Do I STI 
T 


I, _ _ 
LSTARTBIT 
'------SEVEN DATA BITS 


ODD PARITY 


TWO STOP BITS 


Transmitted Data 
(With Parity) 


regardless of parity selection. If parity is 
enabled, the eighth data bit is used as the odd 
parity bit. An interrupt request (IRQ4) is 
generated on all transmitted characters. 
Received data must have a start bit, eight 
data bits and at least one stop bit. If parity is 
on, bit 7 of the received data' is replaced by a 
parity error flag. Received characters generate 
the IRQ3 interrupt request. 


I SP I 07 , De , 05 ' D. , 03 ' 021 0, I Do' ST I 


LSTART BIT 
L-..----EIGHT DATA BITS 


'----------ONE STOP BIT 


Received Data 
(No Parity) 


I SP I P I 0.1 051 0.1 031 021 0, I Do I ST I 


II 


LSTART BIT 
'------SEVEN DATA BITS 


L... ________ 
PARITY ERROR FLAG 


L-, ---------ONE 
STOP BIT 


Received Data 
(With Parity) 


Figure 7. Serial Data Formats 


The 28681182 contains two 8-bit program- 
mable counter/timers (To and TIL each driven 
by its own 6-bit programmable prescaler. The 
T 1 prescaler can be driven by internal or ex- 
ternal clock sources; however, the To prescaler 
is driven by the internal clock only. 
The 6-bit prescalers can divide the input fre- 
quency of the clock source by any number 
from 1 to 64. Each prescaler drives its counter, 
which decrements the value (1 to 256) that has 
been loaded into the counter. When the 
counter reaches the end of count, a timer 
interrupt request-IRQ4 (To) or IRQs (Tl)-is 
generated. 
The counters can be started, stopped, 
restarted to continue, or restarted from the 
initial value. The counters can also be pro- 
grammed to stop upon reaching zero (single- 


The 28681182 has 24 lines available for input 
and output. These lines are grouped into three 
ports of eight lines each and are configurable 
as input, output or address. Under software 
control, the ports can be programmed to pro- 


Port 1 is a dedicated 2-BUS compatible' 
memory interface. ThG operations of Port 1 are 
supported by the Address Strobe (AS) and 
Data Strobe (DS) lines, and by the Read/Write 
(R/W) and Data Memory (DM) control lines. 
The low-order program and data memory 
addresses (Ao-A7) are output through Port 1 


pass mode) or to automatically reload the 
initial value and continue counting (modulo-n 
continuous mode). The counters, but not the 
prescalers, can be read any time without 
disturbing their value or count mode. 
The clock source for T 1 is user-definable; it 
can be either the internal microprocessor clock 
divided by four, or an external signal input via 
Port 3. The Timer Mode register configures the 
external timer input as an external clock, a 
trigger input that can be retriggerable or non- 
retriggerable, or as a gate input for the inter- 
nal clock. The counter/timers can be pro- 
grammably cascaded by connecting the To' out- 
put to the input of Tl. Port 3 line P36 also 
serves as a timer output (TOUT) through which 
To, T 1 or the internal clock can be output. 


vide address outputs, timing, status sig~als, 
serial I/O, and parallel I/O with or without 
handshake. All ports have active pull-ups and 
pull-downs compatible with TTL loads. 


(Figure 8) and are multiplexed with data in/out 
(Do-D7). Instruction fetch and data memory 
read/write operations are done through this 
port. 


Port 1 cannot be used as a register nor can a 
handshake mode be used with this port. 
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I/O Ports 
(Continued) 
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Both the 28681 and 28682 wake up with the 8 
bits of Port 1 configured as address outputs for 
external memory. If more than eight address 
line are required with the 28681, additioni,'il 
lines can be obtained by programming Port 0 
bits as address bits. The least-significant four 
bits of Port 0 can be configured to supply ad- 
dress bits Aa-All for 4K byte addressing or 
both nibbles of Port 0 can be configured to 
supply address bits Aa-AIS for 64K byte ad- 
dressing. 


Port 0* can be programmed as a nibble I/O 


port, or as an address port for interfacing 
external memory (Figure 9). When used as an 
I/O port, Port 0 may be placed under hand- 
shake control. In this configuration, Port 3 
lines P32 and P35 are used as the handshake 
controls DAVo and RDYo. Handshake signal 
assignment is dictated by the I/O direction of 
the upper nibble P04-P07. 


For external memory references, Port 0 can 
provide address bits As-All (lower nibble) or 
As-AIS (lower and upper nibbles) depending 
on the required address space. If the address 
range requires 12 bits or less, the upper nibble 
of Port 0 can be programmed independently as 
I/O while the lower nibble is used for 
addressing. 
. 


In the Z8681 *, Port 0 lines float after reset; 
their logic state is unknown until the execu- 
tion of ap initialization routine that configures 
Port O. 
Such an initialization routine must reside 
within the first 256 bytes of executable code 
and must be physically mapped into memory 
by forcing the Port 0 address lines to a known 
state. See Figure 10. The proper Port initializa- 
tion sequence is: 


1. Write initial address (As-AlS) of initializa- 
tion routine to Port 0 address lines. 
2. Configure Port 0 Mode Register to oufput 
Aa-Als (or Aa-All)· 


To permit the use of slow memory, an' 
automatic wait mode of two oscillator clock 
cycles is configured for the bus timing of the 
28681 after each reset. The initialization 
routine could include reconfiguration to 


PORT 1 
(1/0 OR ADo-AD1 


TO EXTERNAL 
MEMORY 


Figure 8. Port 1 


eliminate this extended timing mode. 
The following example illustrates the manner 
in which an initialization routine can be 
mapped in a 28681 system with 4K of memory. 


Example. In Figure 10, the initialization 
routine is mapped to the first 256 bytes of pro- 
gram memory. Pull-down resistors maintain the 
address lines at a logic 0 level when these 
lines are floating. The leakage current caused 
by fanout must be taken into consideration 
when selecting the value of the pulldown 
resistors: The resistor value must be large 
enough to allow the Port 0 output driver to pull 
the line to a logic one. Generally, pulldown 
resistors are incompatible with TTL loads. If 
PortO drives into TTL input loads (ILOW = 1.6 
ma) the external resistors should be tied to 
Vee and the initialization routine put in ad- 
dress space FFOOH-FFFFH. 


In the Z8682 *, Port 0 lines are configured as 
address lines Aa-:-A15 after a Reset. If one or 
both nibbles are needed for I/O operation, 
they must be configured by writing to the Port 
o Mode register. The 28682 is in the fast 
memory timing mode after Reset, so the ini- 
tialization routine must be in fast memory. 


~}P04-P01 }PORTO 
POO-P03 
(1/0 OR AS-A15 
Z8681182 
4 
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Figure 9. Port 0 
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PROGRAM 
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Figure 10. Port 0 Address Lines Tied to Logic 0 


'This feature differs in the 28681 and 28682 


2194-007,008,009 


I/O Ports 
(Continued) 


Interrupts* 


Clock 


2194-010, 011 


Port 2 bits can be programmed indepen- 
dently as input or output (Figure 11). This port 
is always available for I/O operations. In addi- 
tion, Port 2 can be configured to provide 
open-drain outputs. 
Like Port 0, Port 2 may also be placed under 
handshake control. In this configuration, Port 
3 lines P31 and P36 are used as the handshake 
controls lines DAV2 and RDY2. The handshake 
signal assignment for Port 3 lines P31 and P36 
is dictated by the direction (input or output) 
assigned to bit 7 of Port 2. 


Port 3 lines can be configured as I/O or con- 
trol lines (Figure 12). In either case, the direc- 
tion of the eight lines is fixed as four input 
(P30-P33) and four output (P34-P37)' For serial 
I/O, lines P30 and P37 are programmed as 
serial in and serial out, respectively. 


Port 3 can also provide the follOWing control 
functions: handshake for Ports 0 and 2 (DAV 
and RDY); four external interrupt 
request signals (IRQo-IRQ3); timer input and 
output signals (T.lli....9nd TOUT) and Data 
Memory Select (DM). 


The Z8681182 allows six different interrupts 
from eight sources: the four Port 3 lines 
P30-P33, Serial In, Serial Out, and the two 
counter/timers. These interrupts are both 
maskable and prioritized. The Interrupt Mask 
register globally or indiVidually enables or 
disables the six interrupt requests. When more 
than one interrupt is pending, priorities are 
resolved by a programmable priority encoder 
that is controlled by the Interrupt Priority 
register. 
All Z8681 and Z8682 interrupts are vectored 
through locations in program memory. When 
an interrupt request is granted, an interrupt 
machine cycle is entered. This disables all 
subsequent interrupts, saves the Program 
Counter and status flags, and accesses the pro- 
gram memory vector location reserved for that 
interrupt. In the Z8681, this memory location 
and the next byte contain the 16-bit address of 
the interrupt service routine for that particular 
interrupt request. The Z8681 takes 26 system 
clock cycles to enter an interrupt subroutine. 
The Z8682 has a small internal ROM that 
contains six 2-byte interrupt vectors pointing to 


The on-chip oscillator has a high-gain, 
parallel-resonant amplifier for connection to a 
crystal or to any suitable external clock source 
(XTALl = Input, XTAL2 = Output). 
The crystal source is connected across 
XTALI and XTAL2, using the recommended 
capacitance (CL = 15 pF maximum) from each 
pin to ground. The speCifications for the 
crystal are as follows: 


"This feature differs in the 28681 and 28682 
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Figure 11. Port 2 


PORT 3 
(1/0 OR CONTROL) 


Figure 12. Port 3 


addresses 2048-2065, where 3-byte jump ab- 
solute instructions are located (See Figure 4). 
These jump instructions each contain a I-byte 
opcode and a 2-byte starting address for the 
interrupf service routine. The Z8682 takes 36 
system clock cycles to enter an interrupt 
subroutine. 


Table 1. Z8682 Interrupt Processing 


Address 
(Hex) 
Contains Jump Instruction and 
Subroutine Addr.ess For 


SOO-S02 
S03-S05 
S06-S0S 
S09-SOB 
SOC-SOE 
BOF-Sll 


IRQO 
IRQl 
IRQ2 
IRQ3 
IRQ4 
IRQS 


Polled interrupt systems are also supported. 
To accommodat~ a polled structure, any or all 
of the interrupt inputs can be masked and. the 
Interrupt Request register polled to determine 
which of the interrupt requests needs service. 


Iii AT cut, parallel-resonant 


III Fundamental type 


II Series resistance, Rs ::s; lOOn 


• For Z8681/Z8682, 8 MHz maximum 
.. For Z8681/Z8682-12, 12 MHz maximum 
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The low-power standby mode allows power 
to be removed without losing the contents of 
the 124 general-purpose registers. This mode 
is available only to the user as a bonding 
option whereby pin 2 (normally XTAL2) is 
replaced by the VMM (standby) power supply 
input. This necessitates the use of an external 
clock generator (input = XTALl) rather than a 
crystal source. 
The removal of power, whether intended or 
due to power failure, must be preceded by a 
software routine that stores the appropriate 
status into the register file. Figure 13 shows 
the recommended circuit for a battery back-up 
supply system. 


Although the 28681 and 28682 have minor 
differences, a system can be designed for com- 
patibility with both ROMless versions. To 
achieve interchangeability, the design must 
take into account the special requirements of 
each device in the external interface, in- 
itialization, and memory mapping. 
External Interface. The 28682 requires a 
7.5 V positive logic level on the RESET pin for 
at least 6 clock periods immediately following 
reset, as shown in Figure 14. The 28681 re- 
quires a 3.8 V or higher positive logic level, 
but is compatible with the 28682 RESET 
waveform. Figure 15 shows a simple circuit for 
generating the 7.5 V level. 


7.35 TO 8.0 V 


/ 


,----"""TX----- VRH 
\ 
'- -- - 
-VRH 
3.8V MIN 


VRL----' 


4 
6 
.. ~r~~" -- ~r~~.- 


MAX 
MIN 


Figure 14. Z8682 RESET Pin Input Waveform 
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Figure 15. RESET Circuit 


+5 V o------..--~ Vee 
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Figure 13. Recommended Driver Circuit for 
Power-Down Operation 


Initialization. The 28681 wakes up after reset 
with Port 0 configured as an input, which 
means Port 0 lines·are floating in a high- 
impedance state. Because of this pullup or 
pulldown, resistors must be attached to Port 0 
lines to force them to a valid logic level until 
Port 0 is configured as an address port. 


Port 0 initialization is discussed in the sec- 
tion on ports. An example of an initialization 
routine for 28681128682 compatibility is shown 
in Table 2. Only the 28681 need execute this 
program. 


Address 


OOOC 


OOOF 


0012 


65536 


2066 


2063 


2060 


2057 


2054 


2051 


2048 


2047 


21 


18 


15 


12 


10 


Table 2. Initialization Routine 


Opcodes Instruction 
Comments 


E6 00 00 
LD PO #%00 
Set AS-AI5 to O. 


E6 F8 96 
LD POlM #%96 Configure Port 0 as 


8D 0812 IP START 
ADDRESS 


APPLICATION 


PROGRAM 


A.P. PROG START ADDRESS 


JP IR05 


JP IR04 


JP IR03 


JP IR02 


JP IROl 


JP IROO 


NOT USED 


JP %0812 


LD P01M ~%96 


LD PO #%00 


IROS 


IR04 


IR03 


IR02 


IROl 


IROO 


AS-AI5. Eliminate ex- 
tended memory timing. 


Execute application 
program. 


15H 


Z8682 VECTORS 
JUMP INSTRUCTIONS 


I 


Z8681 
INITIALIZATION 


Z8681 
VECTORS 


Figure 16. Z8681/82 Logical Program Memory Mapping 


2194-012, 013, 014, 015 
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Notation 
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Memory Mapping. The 28681 and 28682 
lower memory boundaries are located at 0 and 
2048, respectively. A single program ROM can 
be used with either product if the logical pro- 
gram memory map shown in Figure 16 is 
followed. The 28681 vectors and initialization 


17FF 


1015 
1014 


1000 
FFF 


812 
811 


800 
7fF 


15 
14 


APPLICATION 


PROGRAM 


NOT USED 


APPLICATION 
PROGRAM 


Z8682 VECTORS 


NOT USED 


za681 VECTORS 


AND INITIALIZATION 


LOGICAL 
MEMORY 


6K 
- 


4K 


2K 


0 


routine must be starting at address 0 and the 
28682 3-byte vectors (jump instructions) must 
beat address 2048 and higher. Addresses in 
the range 21-2047 are not used. Figure 17 
shows practical schemes. for implementing this 
memory map using 4K and 2K ROMs. 


~ 


CHIP SELECT = (.\12 + Ali) • Al3 • A 4' Als 
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a. Logical to Physical Memory Mapping for 4K ROM 


FFF 


835 
834 


820 
81F 
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811 


800 
7FF 


15 
14 


APPLICATION 


PROGRAM 


NOT USED 


APPLICATION 


PROGRAM 


Z8682 VECTORS 


NOT USED 


Z8681 VECTORS 


AND INITIALIZATION 


LOGICAL 
MEMORY 


- 
r-- 


~ 


r- 


CHIP SELECT = Ali • Ai2 • A13 • ~ 


A10 :0-- A TO ROM 
As 
s 


PHYSICAL 
MEMORY 


.A;5 


7FF 


35 
34 


20 
IF 


12 
11 


b. Logical to Physical Memory Mapping for 2K ROM 


Figure 17. Practical Schemes for Implementing Z8681 and Z8682 Compatible Memory Map 


Addressing Modes. The following notation is used 
to describe the addressing modes and instruction 
operations as shown in the instruction summary. 


IRR 
Indirect register pair or indirect working-register 
pair address 
Irr 
Indirect working-register pair only 
X 
Indexed address 
DA 
Direct address 
RA 
1M 
R 


IR 


Ir 
RR 


Relative address 
Immediate 
Register or working-register address 
Working-register address only 
Indirect-register or indirect working-register 
address 
Indirect working-register address only 
Register pair or working register pair address 


Symbols. The following symbols are used in 
describing the instruction set. 
dst 
Destination location or contents 


src 
Source location or contents 
cc 
Condition code (see list) 


@ 
Indirect address prefix 


SP 
Stack pointer (control registers 254-255) 


PC 
Program counter 
FLAGS Flag register (control register 252) 
RP 
Register pointer (control register 253) 
IMR 
Interrupt mask register (control register 251) 


Assignment of a value is indicated by the symbol 


\\-". For example, 
dst - 
dst + src 
indicates that the source data is added to the 
destination data and the result is stored in the 
destination location. The notation \\addr(n)" is used 
to refer to bit \\n" of a given location. For example, 
dst (7) 
refers to bit 7 of the destination operand. 
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Flags. Control Register R252 contains the following 
six flags: 
Affected flags are indicated by: 
o 
Cleared to zero 
Set to one 
C 
Z 
S 
V 
D 
H 


Carry flag 
Zero flag 
Sign flag 
Overflow flag 
Decimal-adjust flag 
Half-carry flag 


Value 


1000 
0111 
1111 
0110 
1110 
1101 
0101 
0100 
1100 
0110 
1110 
1001 
0001 
1010 
0010 
1111 
0111 
1011 
0011 
0000 


OPC 
dst 


OPC 


VALUE 


dst I OPC 


VALUE 


I 
d.tlCC~~ OPC 


Mnemonic 


C 
NC 
Z 
NZ 
PL 
MI 
OV 
NOV 
EQ 
NE 
GE 
LT 
GT 
LE 


UGE 
ULT 
UGT 
ULE 


OR 11 1 1 01 dsl/src 1 


I OR 11 1 101 
dst 


OR It 1 1 01 
arc 


* 
Set or cleared according to operation 
Unaffected 


dst 


X 
Undefined 


Always true 
Carry 
No carry 
Zero 
Not zero 
Plus 
Minus 
Overflow 
No overflow 
Equal 
Not equal 


Meaning 


Greater than or equal 
Less than 
Greater than 
Less than or equal 
Unsigned greater than or equal 
Unsigned less than 
Unsigned greater than 
Unsigned less than or 'equal 
Never true 


OPC 


OPC 


CCF, 01, EI, IRET, NOP, 
RCF, RET, SCF 


INCr 


One-Byte Instruction 


CLR, CPL, DA, DEC, 
DECW, tNC, INCW, POP, 
PUSH, RL, RLC, RR, 
RRC, SRA, SWAP 


JP, CALL (Indirect) 


C 
1 
C = a 
Z = 1 
Z = 0 
S 
= a 


S 
= 1 


V = 1 
V 
= a 


Z = 1 
Z 
= a 


Flags Set 


(S,XOR V) = a 
(S XOR V) = 1 
[Z OR (S XOR V)] = a 
[Z OR(S XOR V)] = 1 
c=o 
C = 1 
(C = a AND Z = 0) 
,(C OR Z) = 1 


ADC, ADD, AND, CP, 
LD, OR, SBC, SUB, 
TCM, TM, XOR 


I-~~:=--l OR j11 1 0 I dst 


ADC, ADD, AND, CP, 
LD, OR, sec, SUB, 
TCM, TM, XOR 


SRP 


LD 


ADC, ADD, AND, 
CP, OR, SBC, SUB, 
TCM, TM, XOR 


LD 
LD, LDE, LDEI, 
LDC, LOCI 


LO 
JP 


LO 


CALL 


DJNZ, JR 


Two-Byte Instruction 
Three-Byte Instruction 


Figure 18. Instruction Formats 
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Instruction 
Instruction 
Addr Mode 
Opcodo Flags Affected 
Instruction 
Addr Mode 
Opcode Flags Affected 
Summary 
and Operation 
clst 
Byte 
and Operation 
dst 
Byte 


arc 
(Hex) 
CZSVDH 
src 
(Hex) 
CZSVDH 


ADC dst,src 
(Note 1) 
10 
* * * * 0 * 
LDE dst,src 
r 
Irr 
82 
------ 
dst - dst + src + C 
dst - 
src 
Irr 
92 


ADD dst,src 
(Note 1) 
00 
* 0 * 
LDE! dst,src 
Ir 
Irr 
83 
------ 
dst - 
dst + src 
dst - 
src 
Irr 
Ir 
93 


AND dst,src 
(Note 1) 
50 
-**0-- 
r - r + 1; rr - rr + 1 


dst - 
dst AND src 
NOP 
FF 
------ 


CALL dst 
DA 
D6 
------ 
OR dst,src 
(Note 1) 
40 
-**0-- 
SP - 
SP - 2 
IRR 
D4 
dst - dst OR src 


@SP - PC; PC - dst 
POP dst 
R 
50 
------ 
CCF 
EF 
* - - - - - 
dst - 
@SP 
IR 
51 
C - 
NOT C 
SP - 
SP + 1 


CLR dst 
R 
BO 
------ 
PUSH src 
R 
70 
------ 
dst - 
0 
IR 
Bl 
SP - SP -1; @SP- src 
IR 
71 


COM dst 
R 
60 
- 
* * 0 - - 
RCF 
CF 
0-- - - - 
dst - 
NOT dst 
IR 
61 
C-O 


CP dst,src 
(Note 1) 
AD 
RET 
AF 
------ 
N 
dst - src 
PC - @ SP; SP - SP + 2 
ro 
DA dst 
R 
40 
* X - - 
RL dst 
~I~ 
90 
." 


dst - 
DA dst 
IR 
41 
91" 
CO 
~ 


DEC dst 
RLC dst l&-i, 
.~ I~ 
10 
- 
R 
00 
- * **-- 
CO 


dst - 
dst - 1 
IR 
01 
11 
~ 


RR dst 
~y, '~I~ 
EO 
ac 
DECW dst 
RR 
80 
-***-- 
dst - 
dst - 1 
IR 
81 
El 
n 


RRC dst LE1=ciJ R 
CO 
CI 


DI 
c 
, 
• 
IR 
Cl 
IMR (7) - 
0 
8F 
------ 
SBC dst,src 
(Note 1) 
3D 
* * 1 * 
DINZ r,dst 
RA 
rA 
------ 
dst - dst - src - C 


r - 
r - 1 
r=O-F 
SCF 
DF 
1 - - - - - 
if r *" 0 
C-l 


PC - 
PC + dst 
SRA dst L{ri~R 
Range: + 127, -128 
DO 
***0-- 


IR 
Dl 
EI 
9F 
------ 
SRP src 
1m 
31 
------ 
IMR (7) - 
1 
RP - 
src 


INC dst 
rE 
- * * * - - 
SUB dst,src 
(Note 1) 
20 
* * * * 1 * 
dst - 
dst + 1 
r=O-F 
dst - dst - src 
R 
20 


IR 
21 
SWAPdst~ R 
FO 
X * * X - 
- 


INCW dst 
RR 
AO 
IR 
Fl 
- * * * - - 
dst - 
dst + 
IR 
Al 
TCM dst,src 
(Note 1) 
60 
-**0-- 


IRET 
BF 
* * * * * * 


(NOT dst) AND src 


FLAGS - @SP; SP - SP + 1 
TM dst, src 
(Note 1) 
70 
-**0-- 
PC - @SP; SP - SP+ 2; IMR(7) -1 
dst AND src 


IP cc,dst 
DA 
cD 
------ 
XOR dst,src 
(Note 1) 
BO 
-**0-- 
if cc is true 
c=O-F 
dst - dst XOR src 


PC - 
dst 
IRR 
30 


JR cc,dst 
RA 
cB 
------ 
Noto 1 
if cc is true, 
c=O-F 
PC - PC + dst 
These instructions have an identical set of addressing 
Range: + 127, -128 
modes, which are encoded for brevity. The first opcode 


LD dst,src 
1m 
rC 
nibble is found in the instruction set table above. The 
r 
------ 
second nibble is express~d symbolically by a 0 in this 
dst - 
src 
r 
R 
r8 
table, and its value is found in the follOWing table to the 
R 
r9 


r=O-F 
left of the applicable addressing mode pair. 


r 
X 
C7 
For example, to determine the opcode of an ADC 
X 
r 
D7 
instruction using the addreSSing modes r (destination) and 
r 
Ir 
E3 
Ir (source) is 13. 
Ir 
r 
F3 
R 
R 
E4 
Addr Mode 
R 
IR 
E5 
Lower 
R 
1M 
E6 
dst 
src 
Opcode Nibble 
IR 
1M 
E7 
IR 
R 
F5 
[l] 


LDC dst,src 
r 
Irr 
C2 
------ 
Ir 
rn 


dst - 
src 
Irr 
D2 
R 
R 
[i] 


LDCI dst,src 
Ir 
Irr 
C3 
------ 
R 
IR 
@] 


dst - 
src 
Irr 
Ir 
D3 
R 
1M 
@) 
r - r + 1; rr - rr + 1 
IR 
1M 
rn 
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Registers 
R240 SIO 


Serial 1/0 Register 
(FOH; ReadlWrite) 


L-----SERIAL DATA (Do = LSB) 


'R241 TMR 
Time Mode Register 
(FIH; ReadlWrite) 


NOT USED .. 00 -.J, 
1 .. LOAD To 


~o g~~ : ~~ 
0 .. DISABLE To COUNT 


TouJMODES Ij~~O=NOFUNCTION 


INTERNAL CLOCK OUT .. 11 
1 .. ENABLE To COUNT 


T 
MODES 
0 .. NO FUNCTION 


EXTERNAL CLOCK IN~OT .. 00 
1 .. LOAD Tt 
GATE INPUT· 01 
0 .. DISAIILE Tt COUNT 


(NON.~~k~g~:~~:~~ • 10 
1 .. ENABLE Tt COUNT 
TRIGGER INPUT. 11 
(RETRIGGERABLE) 


R242 TI 
Counter Timer 1 Register 
(F2H; ReadlWrite) 


Tt INITIAL VALUE (WHEN WRITTEN) 
L-----(RANGE 1-256 DECIMAL 01-00 HEX) 
Tt CURRENT VALUE (WHEN READ) 


R243 PREl 


Prescaler 1 Register 
(F3H; Write Only) 


I~I~I~I~I~I~I~I~I 


~ 


COUNTMODE 


1 = Tt MODULO·N 
o .. Tt SINGLE·PASS 


CLOCK SOURCE 


1 = Tt INTERNAL 
o = Tt EXTERNAL 


TIMING INPUT 
(T,N) MODE 


PRESCALER MODULO 
L-------(RANGE: 1-64 DECIMAL 
01-00 HEX) 


R244 TO 


Counter/Timer 0 Register 
(F4H; ReadIWrite) 


R245 PREO 
Pres caler 0 Register 
(F5H; Write Only) 
l 


COUNTMODE 


o .. To SINGLE·PASS 
1 .. To MODULO·N 


RESERVED (MUST BE 0) 


PRESCALER MODULO 
L------(RANGE: 1-64 DECIMAL 
01-00 HEX) 


R246 P2M 
Port 2 Mode Register 
(F6H; Write Only) 


P20-P2, I/O DEFINITION 
L-____ 0 DEFINES BIT AS OUTPUT 


1 DEFINES'BIT AS INPUT 


R247 P3M 
Port 3 Mode Register 
(F7H; Write Only) 


~~ 


O PORT 2 PULL,UPS OPEN DRAIN 
1 PORT 2 PULL·UPS ACTIVE 


RESERVED (MUST BE 0) 
o P32 = IN PUT 
P3s = OUTPUT 


1 P32 = IlAVO/RDYO P3s = RDYO/1lAVO 


o 0 
P33 = INPUT 
P34 = OUTPUT 


~ ~} P33 = INPUT 
P34 = D'M 


1 1 P33 = DAVl/RDY1 P34 = RDY1/DAV1 


'--------~ ~~: ~ ~N:VUJto~~ ~~: ~ ~~~~~UT) 


L.-_~-----~ 
~~~ ~ kN~~lL IN 
~~~ ~ ~~~i'AULTOUT 
'--________ 
~ ~~=:~~ g~F 


Figure 19. Control Registers 
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2037-014 


R248 POIM 
'Port 0 Register 
(F8H; Write Only) 


PO.-PO, MODE:] ~~ 
PO.-PO. MODE 
OUTPUT = 00 -.J 
' 
L 
00 = OUTPUT 
INPUT = 01 
01 = INPUT 


A12-A,s .. IX 
_ 
IX = A.-A" 


EXTERNAL 
STACK SELECTION 
MEMORY TIMING 
0 = EXTERNAL 


NORMAL = 0 
1 = INTERNAL 


'EXTENDED = 1 


RESERVED (MUST BE 0) 


'ALWAYS EXTENDED TIMING AFTER RESET 


R2491PR 


Interrupt Priority Register 
(F9H; Write Only) 


10,1 0.1 05 1 0.1 D. \ O2 \ 0, I D. I 


INTERRUPT GROUP PRIORITY 
RESERVED = 000 
C > A > B = 001 


RESERVED :OJ I 


IR03. IROS PRIORITY (GROUP A) 
o = IROS > IR03 
'---+-+-- 
A > B > C = 010 


1 = IR03 > IROS 


IROO. IR02 PRIORITY (GROUP B) 
o = IR02 > IROO --------' 
1 = IROO > IR02 


IROI. IR04 PRIORITY (GROUP C) 
o = IROI > IR04 --------' 
1 = IR04 > IROI 


A> C > B = 011 
B > C > A = 100 
C> B > A = 101 
B > A > C = 110 
RESERVED = 111 


R250 IRQ 
Interrupt Request Register 
(FAH; Read/Write) 


I~I~I~I~I~I~I~I~I 


RESERVED (MUST BE o)::r- 
c-= 
IROO - 
P32 INPUT (Do .. IROO) 
IROl .. P33 INPUT 
IR02 .. P31 INPUT 
IR03 .. P30 INPUT. SERIAL INPUT 
IR04 .. To. SERIAL OUTPUT 
IROS" Tl 


R251lMR 
Interrupt Mask Register 
(FBH; Read/Write) 


I~I~I~I~I~I~I~I~I 
II 
c-= 
1 ENABLES IROO-IROS 
(00 = IROO) 
L.....-------RESERVED (MUST BE 0) 
'---------1 ENABLES INTERRUPTS 


REGISTER 
POINTER 


Figure 19, Control Registers (Continued) 


R252 FLAGS 
Flag Register 
(FCH; Read/Write) 


LUSER FLAG F2 


. 
HALF CARRY FLAG 
~~~ 


LUSERFLAGFl 


DECIMAL ADJUST FLAG 


OVERFLOW FLAG 


SIGN FLAG 


ZERO FLAG 


L...--------CARRY FLAG 


R253 RP 


Register Pointer 
(FDH; Read/Write) 


R254 SPH 


Stack Pointer 
(FEH; Read/Write) 


R255 SPL 


Stack Pointer 


(FFH; Read/Write) 
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Z8681/82 
Opcode 
Map 


o 


2 


3 


4 


5 


)( 
6 


III ;. 


III 
:Q 
1 


:9 z .. 
III 
C. 
8 
c. 
~ 


9 


A 


B 


C 


D 


E 


F 


o 


6,5 
DEC 


Rl 


6,5 
RLC 


Rl 


6,5 
INC 
Rl 


8,0 
JP 
IRRI 


8,5 
DA 
Rl 


10,5 
POP 


Rl 


6,5 
COM 


Rl 


10/12,1 
PUSH 


R2 


10,5 


DECW 


RRI 


6,5 
RL 
Rl 


10,5 
INCW 


RRI 


6,5 
CLR 
Rl 


6,5 
RRC 
Rl 


6,5 
SRA 
Rl 


6,5 
RR 
Rl 


8,5 


SWAP 


Rl 


6,5 
DEC 
IRl 


6,5 
RLC 
IRl 


6,5 
INC 
IRI 


6,1 
SRP 
1M 


8,5 
DA 
IRl 


10,5 
POP 
IRI 


6,5 
COM 
IRI 


12/14,1 
PUSH 


IR2 


10,5 
DECW 
IRl 
6,5 
RL 
IRl 


10,5 
INCW 
IRl 


6,5 
CLR 
IRl 


6,5 
RRC 
IRI 
6,5 
SRA 
IRl 


6,5 
RR 
IRI 


8,5 


SWAP 


IRl 


2 
3 


6,5 
6,5 
ADD 
ADD 


fl, r2 
rl,Ir2 


6,5 
6,5 


ADC 
ADC 


rl, r2 
r l,Ir2 


6,5 
6,5 


SUB 
SUB 


rl, r2 
rl,Ir2 


6,5 
6,5 


SBC 
SBC 


rl, r2 
rl,Ir2 


6,5 
6,5 


OR 
OR 


rl, r2 
rl,Ir2 


6,5 
6,5 
AND 
AND 
rl, r2 
rl,Irz 


6,5 
6,5 
TCM 
TCM 


fl, fZ 
rl,lrz 


6,5 
6,5 
TM 
TM 
rl, r2 
rl,lrz 


12,0 
18,0 


LDE 
LDEI 


fl,Irr2 Ir I, Irr2 


12,0 
18,0 


LDE 
LDEI 
r2,Irrl Ir2, Irfl 


6,5 
6,5 


CP 
CP 


rl, r2 
rl,Irz 


6,5 
6,5 


XOR 
XOR 


rl, r2 
rl,Irz 


12,0 
18,0 


LDC 
LDCI 


rl,lrrz Irl,lrrz 


12,0 
18,0 


LDC 
LDCI 


rz,Irrl Irz,lrrl 


6,5 
LD 


rl,IRz 


6,5 
LD 
Irl, r2 


Lower Nibble (Hex) 


4 
5 
6 
1 
8 
9 
A 
B 
C 
D 
E 
F 


10,5 
10,5 
10,5 
10,5 
6,5 
6,5 
12/10,5 
12/10,0 
6,5 
12/10,0 
6,5 
ADD 
ADD 
ADD 
ADD 
LD 
LD 
DJNZ 
JR 
LD 
JP 
INC 
R2,Rl 
IR2,Rl 
Rl,IM 
IRl,IM 
rl,R2 
r2, Rl 
fl,RA 
cc,RA 
rl,IM 
cc,DA 
fl 
10,5 
10,5 
10,5 
10,5 
r--- 
ADC 
ADC 
ADC 
ADC 


R2,Rl 
IR2,Rl 
Rl,IM 
IRl,IM 


10,5 
10,5 
10,5 
10,5 
r--- 
SUB 
SUB 
SUB 
SUB 


R2,Rl 
IR2,Rl 
Rl,IM 
IRl,IM 
- 
10,5 
10,5 
10,5 
10,5 
SBC 
SBC 
SBC 
SBC 


R2,Rl 
IR2,Rl 
Rl,IM 
IRl,IM 
- 
10,5 
10,5 
10,5 
10,5 
OR 
OR 
OR 
OR 


R2,Rl 
IR2,Rl 
Rl,IM 
IR1,IM 
- 
10,5 
10,5 
10,5 
10,5 


AND 
AND 
AND 
AND 
R2,Rl 
IR2,Rl 
Rl,IM 
IRl,IM 


10,5 
10,5 
10,5 
10,5 
r--- 


TCM 
TCM 
TCM 
TCM 


Rz,Rl 
IR2,Rl 
Rl,IM 
IR1,IM 


10,5 
10,5 
10,5 
10,5 
r--- 


TM 
TM 
TM 
TM 
R2,Rl 
IR2,Rl 
Rl,IM 
IRl,IM 
r--- 


6,1 
DI 


r--- 


6,1 
EI 


>---- 
10,5 
10,5 
10,5 
10,5 
14,0 
CP 
CP 
CP 
CP 
RET 
R2,Rl 
IRZ,Rl 
Rl,IM 
IRl,IM 
- 
10,5 
10,5 
10,5 
10,5 
16,0 
XOR 
XOR 
XOR 
XOR 
IRET 
R2,Rl 
IR2,Rl 
Rl,IM 
IRl,IM 
- 
10,5 
6,5 
LD 
RCF 
rl, x, Rz 
- 
20,0 
20,0 
10,5 
6,5 
CALL· 
CALL 
LD 
SCF 
IRRI 
DA 
rz, x, Rl 
t--- 
10,5 
10,5 
10,5 
10,5 
6,5 
LD 
LD 
LD 
LD 
CCF 
R2,Rl 
IRz,Rl 
Rl,IM 
IR1,IM 
r--- 
10,5 
6,0 
LD 
1 
NOP 
R2,IRl 


'" 
'" 


,.I '" 
,/ 


Bytes per 
V' 
V' 
~--------~~~----------~~ ~ 
~ 


Instruction 
2 
3 
Lower 
Opcode 
Nibble 


Execution 
~ 
Pipeline 
Cycles 
Cycles 


Upper 
Opcode-' A 
Mnemonic 


~Ibble 


First 
Second 
Operand 
Operand 


*2-byte instruction; fetch cycle appears as a 3-byte instruction 
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2 


Legend: 
R = 8-Bit Address 
r = 4-Bit Address 
HI or rl = Dst Address 
Hz or rz = Src Address 


Sequence: 


3 


Opcode, First Operand, Second Operand 


Note: The blank areas are not defined_ 


8085-002 


Absolute 
Maximum 
Ratings 


Standard 
Test 
Conditions 


DC 
Character- 
istics 


8085-0313, 2037-015 


Voltages on all pins* 
with respect to GND .......... -0.3 V to +7.0 V 
Operating Ambient 
Temperature ........ See Ordering Information 


Storage Temperature ........ -65°C to + 150°C 


The characteristics below apply for the 
following standard test conditions, unless 
otherwise noted. All voltages are referenced to 
GND. Positive current flows into the reference 
pin. Standard conditions are as follows: 
m +4.75 V :s; Vee ~ +5.25 V 


+SV 


2.1K 


Figure 20. Test Load 1 


Symbol 
Parameter 
Min 
Max 


VeH 
Clock Input High Voltage 
3.8 
Vee 


VeL 
Clock Input Low Voltage 
-0.3 
0.8 


VIH 
Input High Voltage 
2.0 
Vee 


VIL 
Input Low Voltage 
-0.3 
0.8 


VRH 
Reset Input High Voltage 
3.8 
Vee 


VRL 
Reset Input Low Voltage 
-0.3 
0.8 


VOH 
Output High Voltage 
2.4 


VOL 
Output Low Voltage 
0.4 


IlL 
Input Leakage 
-10 
10 


10L 
Output Leakage 
-10 
10 


1m 
Reset Input Current 
-50 


lee 
Vee Supply Current 
180 


IMM 
VMM Supply Current 
10 


VMM 
Backup Supply Voltage 
3 
Vee 


NOTE: 


Stresses greater than those listed under Absolute Maxi- 
mum Ratings may cause permanent damage to the device. 
This is a stress rating only; operation of the device at any 
condition above those indiCated in the operational sections 
of these specifications is not implied. Exposure to absolute 
maximum rating conditions for extended periods may affect 
device reliability. 


• GND = 0 V 
• O°C :s; TA :s; +70°C for S (Standard 
temperature) 


g -40°C :s; TA S + 85°C for E (Extended 
temperature) 


+SV 
+sv 


1.Sk 
1.Sk 


14LS04 
14LS04 


XTAL1 


Figure 21. External Clock Interface Circuit 


Unit 
Condition 


V 
Driven by External Clock Generator 


V 
Driven by External Clock Generator 


V 


V 


V 
See Note 


V 


V 
IoH = -250 p.A 


V 
IoL = +2.0 rnA 


p,A o v's VIN S +5.25 V 


p.A o Vs VIN s +5.25 V 


p.A 
Vee = .+5.25 VI VRL = 0 V 


rnA 


rnA 
Power Down Mode 


V 
Power Down 


The Reset line (pin 6) is used to place the 28682 in external memory mode. This is accomplished as shown in Figure 14 . 


• Except RESET Pin 6 
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N 
CO 
en 
CO ... -= 
iI " 
CI 


External 1/0 
RlW 
or Memory 
Read and 
Write Timing 
PORT 0, 


DM 


PORT 1 


As 


os 


(READ) 


PORT 1 
AfJ-A7 


os 
(WRITE) 


Figure 22. External I/O or Memory Read/Write Timing 


No. 
Symbol 
Parameter 


1 
TdA(AS) 
Address Valid to AS t Delay 
2 
TdAS(A) 
AS t to Address Float Delay 
3 
TdAS(DR) 
AS t to Read Data Required Valid 


4 
TwAS 
AS Low Width 
5 
TdAz(DS) 
Address Float to DS , 


6-TwDSR 
DS (Read) Low Width 
7 
TwDSW 
DS (Write) Low Width 
8 
TdDSR(DR) 
DS , to Read Data Required Valid 


9 
ThDR(DS) 
Read Data to DS t Hold Time 


10 
TdDS(A) 
DS t to Address Active Delay 


11 
TdDS(AS) 
DS t to AS , Delay 
12-TdRlW(AS)--RlW Valid to AS t Delay 


13 
TdDS(R/W) 
DS t to R/W Not Valid 


14 
TdDW(DSW) 
Write Data Valid to DS (Write) , Delay 


15 
TdDS(DW) 
DS t to Write Data Not Valid Delay 


Z8681/82 
8 MHz 
Min 
Max 


50 
70 
360 
80 
0 
250 


160 
200 
0 
70 
·70 
50 
60 
50 
70 


Z8681/82 
12MHz 
Min 
Max 


35 
45 


220 


55 


0 


185 


110 
130 
0 
45 
55 
30 
35 
35 
45 


Notes*t 


1,2,3 
1,2,3 
1,2;3,4 
"1,2,3 


1,2,3,4 
1,2,3,4 
1,2,3,4 


1,2,3 
1,2,3 
1,2,3 
1,2,3 
1,2,3 
1,2,3 


16 
TdA(DR) 
Address Valid to Read Data Required Valid' 
410 
255 
1,2,3,4 


17 
TdAS(DS) 
AS t to DS , Delay 


NOTES: 
1. Test Load 1 
2. Timing numbers given are for minimum TpC. 
3. Also see clock cycle time dependent characteristics table. 
4. When using extended memory timing add 2 TpC. 
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80 
55 
1,2,3 


5. All timing references use 2.0 V for a logic "1" and 0.8 V for a logic "0". 
• All units in nanoseconds (ns). 
t Timings are preliminary and subject to change. 


2194-017 


Additional 
Timing 
Table 


CLOCK 


Till 


Figure 23. Additional Timing 


No. 
Symbol 
Parameter 


TpC 
Input Clock Period 


2 
TrC,TfC 
Clock Input Rise And Fall Times 


3 
TwC 
Input Clock Width 


4 
TwTinL 
Timer Input Low Width 
5--TwTinH 
Timer Input High Width 


6 
TpTin 
Timer Input Period 


7 
TrTin, TfTin 
Timer Input Rise And Fall Times 


8 
TwIL 
Interrupt Request Input Low Time 
9 
TwIH 
Interrupt Request Input High Time· 


NOTES: 
1. Clock timing references uses 3.8 V for a logic "1" and 0.8 V for 
a logic "0". 


2. Timing reference uses 2.0 V for a logic "1" and.o.8 V for 
a logic "0". 


2194-018 


Z8681/82 


8MHz 


Min 
Max 


125 
1000 


25 


37 
100 


3TpC 


TpC 
S- 
100 


100 


Z8681182 
12MHz 
Min 
Max 


83 
1000 


15 


26 
70 


3TpC 
TpC 
S- 


100 
70 


3TpC 
3TpC 


3. Interrupt request via Port 3. 
* Units in nanoseconds (ns). 
t Timings are preliminary and subject to change. 


Notes*; 


N 
00 
'" 
2 
CO ... 


2 - 
00 


2 
~ 
ac 
n 


2 
d 


2,3 


2,3 
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Handshake 
Timing 
DATA IN 


DAV 


(INPUT) 


RDY 


(OUTPUT) 


DATA OUT 


Figure 24a. Input Handshake Timing 
r- 
DATA OUT VALID 
------'~----- 
\)\O--~C:9 
7 . 


No. 
Symbol 


DAV 
(OUTPUT) 


RDY 


(INPUT) 


Parameter 


TsDI(DAV) 
Data In Setup Time 


2 
ThDI(DA V) 
Data In Hold Time 


3 
TwDAV 
Data Available Width 


~ 
0)---~ ~ 


Figure 24b. Output Handshake Timing 


Z8681182 
Z8681/82 
8 MHz 
12MHz 
Min 
Max 
Min 
Max 


0 
0 


230 
160 


175 
120 


Notes*t 


4 
TdDAVIf(RDY) 
DAV I Input to RDY I Delay 
175 


5-TdDAVOf(RDY)-DAV I Output to RDY I Delay 
0 
0 


120 
1,2 
------1,3 


6 
TdDAVIr(RDY) 
DAV I Input to RDY I Delay 


7 
TdDAVOrRDY) 
DAV I Output to RDY I Delay 


8 
TdDO(DAV) 
Data Out to DAV I Delay 


9 
TdRDY(DAV) 
Rdy I Input to DA V I Delay 


NOTES: 
1. Test load I 
2. Input handshake 
3. Output handshake 
4. All timing regerences use 2.0 V for a logic "I" and 0.8 V for 


a logic "0". 


Clock- 
Cycle-Time- 
Dependent 
Number 
Symbol 


Characteristics 
1 
TdA(AS) 


2 
TdAS(A) 


3 
TdAS(DR) 


4 
TwAS 


6 
TwDSR 


7 
TwDSW 


8 
TdDSR(DR) 


10 
Td(DS)A 


11 
TdDS(AS) 


12 
TdR/W(AS) 


13 
TdDS(R/W) 


14 
TdDW(DSW) 


15 
TdDS(DW) 


16 
TdA(DR) 


17 
TdAS(DS) 


• Add 2TpC when using extended memory timing 
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175 
120 


0 
0 


50 
30 


0 
200 
0 
140 


• Units in nanoseconds (ns). 
r Timings are preliminary and subject to change. 


Z8681182 
Z8681/82 
8 MHz 
12 MHz 


Equation 
Equation 


TpC-75 
TpC-50 


TpC-55 
TpC-40 


4TpC-140* 
4TpC-110* 


TpC-45 
TpC-30 


3TpC-125* 
3TpC-65* 


2TpC-90* 
2TpC-55* 


3TpC-175* 
3TpC-120* 


TpC-55 
TpC-40 


TpC-55 
TpC-30 


TpC-75 
TpC-55 


TpC-65 
TpC-50 


TpC-75 
TpC-50 


TpC-55 
TpC-40 


5TpC-215* 
5TpC-160* 


TpC-45 
TpC-30 


1,2 


1,3 


2194-019 


Ordering 
Product 
Package/ 
Product 
Package/ 
Information 
Number 
Temp 
Speed 
Description 
Number 
Temp 
Speed 
Description 


Z8681 
CE 
8.0 MHz 
Z8MCU 
Z8681 
CE 
12.0 MHz 
Z8MCU 


(ROMless, 40-pin) 
(ROMless, 40-pin) 


Z8681 
CS 
8.0 MHz 
Same as above 
Z8681 
CS 
12.0 MHz 
Same as above 


Z8681 
DE 
8.0 MHz 
Same as above 
Z8681 
DE 
12.0 MHz 
Same as above 


Z8681 
DS 
8.0 MHz 
Same as above 
Z8681 
DS 
12.0 MHz 
Same as above 


Z8681 
PE 
8.0 MHz 
Same as above 
Z8681 
PE , 
12.0 MHz 
Same as above 


Z8681 
PS 
8.0 MHz 
Same as above 
Z8681 
PS 
12.0 MHz 
Same as above 


Z8682 
PE 
8.0 MHz 
Same as above 
Z8682 
PE 
12.0 MHz 
Same as above 


Z8682 
PS 
8.0 MHz 
Same as above 
Z8682 
PS 
12.0 MHz 
Same as above 


NOTES: C = Ceramic, D = Cerdip, P = Plastic; E = -40°C to +85°C, S = O°C to +70°C. 
NOTE: The Z8681 is available in the low power standby option. If this option is desired, a 28685 part number should be specified. All other data 
remains the same for ordering purposes. 
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Z8@ Family of 
Universal Peripheral 
«:cnll'laDBlam 


Zilog 


Product 
Specification 


September 1983 


Features 


General 
Description 


Non-Multiplexed Bus 
Z8590-2K HOM 
Z8594-PROM/RAM Protopack 
Z-BUS 
Z8090-2K ROM 
Z8094-PROMIRAM Potopack 


Ell Complete slave 28 microcomputer, for 
distributed processing use. 


S Unmatched power of 28 architecture and 
instruction set. 


II Three programmable I/O ports, two with 
optional 2-Wire Handshake. 


C Six levels of priority interrupts from eight 
sources: six from external sources and two 
from internal sources. 


I!IJ Two programmable 8-bit counter/timers 


The Universal Peripheral Controller 


(UPC) is an intelligent peripheral controller 
for distributed processing applications (Figure 
1). The upe unburdens the host processor by 
assuming tasks traditionally done by the host 
(or by added hardwarE!) , such as performing 
arithmetic, translating or formatting data, and 
controlling I/O devices. Based on tbe 28 
microcomputer architecture and instruction 
set, the UPC contains 2K bytes of internal pro- 
gram ROM, a 256-byte register file, three 8-bit 
I/O ports, and two counter/timers. 
The UPC is offered in two basic configura- 


tions:the 28090/4, which interfaces to 


multiplexe~ address/data CPUs such as the 


each with a 6-bit prescaler. Counter/Timer 
TO is driven by an internal source, and 
Counter/Timer Tl can be driven by internal 
or external sources. Both counter/timers are 
independent of program execution. 


[J 256-byte register file, accessible by both the 
master CPU and UPC, as allocated in the 
UPC program. 


[J 2K bytes Of on-chip ROM for efficiency and 
versatility. 


28000, and the 28590/4, which interfaces with 
non-multiplexed CPUs such as the 280. Both 
devices have the same instruction set and I/O 
port configuration. The difference in the 
devices is in the UPC-to-host interface pins 
and the sequence of data transfer between the 
units. 
The UPC offers fast execution time, an 
effective use of memory, and sophisticated 
interrupt, I/O, and bit manipulation. Using 
a powerful and extensive instruction set 
combined with an efficient internal 
addressing scheme, the UPC speeds 
program execution and efficiently packs 
program code into the on-chip ROM. 
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General 
Description 
(Continued) 
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An important feature of the UPC is an inter- 
nal register file containing I/O port and con- 
trol registers accessed both by the UPC pro- 
gram and indirectly by its associated master 
CPU. This architecture results in both byte 
and programming 'efficiency, because UPC 
instructions can operate directly on I/O data 
without moving it to and from an accumulator. 
Such a structure allows the user to allocate as 
many general-purpose registers as the applica,- 
tion requires for data buffers between the CPU 
and peripheral devices. All general-purpose 
registers can be used as address pointers, 
index registers, data buffers, or stack space. 
The register file is logically divided into 16 
groups, each consisting of 16 working 
registers. A Register Pointer is used in con- 
junction with short format instructions, 
resulting in tight, fast code and easy task 
sWitching. 


Communication between the master CPU 


and the register file takes place via one group 
of 19 interface registers addressed directly by 
both the master CPU and the UPC, or via a 
block transfer mechanism. Access by the 
master CPU is controlled by the UPC to allow 


independence between the master CPU and 
UPC software. 
The UPC has 24 pins that can be dedicated 
to I/O functions. Grouped logically into three 
8-line ports, they can be programmed in many 
combinations of input or output lines, with or 
without handshake, and with push-pull or 
open-drain outputs. Ports 1 and 2 are bit- 
programmable; Port 3 has four fixed inputs 
and four outputs .. 
To relieve software from coping with real- 
time counting and timing problems, the UPC 
has two 8-bit hardware counter/timers, each 
.with a fixed'divide-by-four, and ~ 6-bit pro- 
grammable prescaler . Various counting modes 
may be selected. 
In addition to the 40-pin standard ROM con- 
figuration, the UPC is available in a Protopack 
RAM/ROM version with a socket for up to 2K 
bytes of RAM or ROM and with 36 bytes of in- 
ternal ROM permitting downloading from the 
master CPU. 


This range of versions and configurations 
makes the UPC compatible with most system 
peripheral device control considerations. 


HOST CPU 
INTERFACE 
Z8.UPC MICROCOMPUTER 


Z8D90 
Z8590 


ADo-AD, DBo-DB, 


As 
AID 
os 
AD 


BUS TO 
Riw 
ViR 
MASTER 
Cs 
Cs 
CPU 
WAIT 
WAIT 


iNT 
iNT 


INTACK 
INTACK 


lEI 
lIil 


lEO 
lEO 


Figure I. Functional Block Diagram 


110 


2017-087 


Pin 
Description 
Z8090 
Z-UPC 


2017-069, 095 


ADo-AD1' Z-Bus Address/Data Lines (bidirec- 
tional). These multiplexed address and data 
lines are used to transfer information between 
the master CPU and the slave Z-UPC. 


AS. Address Strobe (input, active Low). The 
rising edge of AS initiates the beginning of a 
transaction and indicates that the Address, 
Status, R/W, and CS signals must be valid. 


PCLK. Clock (input). TTL-compatible clock 
input, 4 MHz maximum. This signal does not 
need to be related to the master CPU clock. 


CS. ChipSelecf (input, active Low). A Low on 
this line during the rising edge of AS enables 
the Z-UPC to accept address or data informa- 
tion from the bus during a master CPU write 
cycle or to transmit data to the bus during a 
read cycle. 


DS. Data Strobe (input, active Low). DS 
provides timing for data movement to the bus 
master. A simultaneous Low on AS and DS 
resets the Z-UPC. It is held in reset as long as 
DS is Low. 


ADDRESS,j ~ 
~l~ 
DATA BUS 
_ 
AD3 


- 
AD2 


- 
ADl 
-ADo 


TIM~~~ { 
AS 


AND RESET 
- 
os 
Z8090 


CONTROL { =: ~ Z·UPC 


WAiT 


{ 


iNfOR P3s 


MASTER 
_ 
INTACK OR P32 


INTERR~~~ 
- 
lEI OR P30 
lEO OR P37 


+sv_ 
PCLK_ 
GND_ 


Pl 
1 _) 
P16- 
Pls- 


P14 
PORT 1 
P13- 
P12- 


Pll 
Plo- 


P33 _} 
P34 


PORT 3 
P3l_ 


P36 


Figure 2. Pin Functions 


P1o-PI1. P2o-P21' P30-P31' I/O Port Lines 
(inputs/outputs, TTL-compatible). These 24 
lines are divided into three 8-bit I/O ports and 
may be configured in the following ways under 
program control: 


P1o-PI1' Port 1 (input/output-as output it can 
be push-pull or open-drain). Bit-programmable 
Parallel I/O. 


P2o-P21' Port 2 (input/output-as output, it can 
be push-pull or open-drain). Bit-programmable 
Parallel I/O. 


P30-P31' Port 3 (four inputs, four outputs). 
Parallel I/O, handshake control, timer I/O, or 
interrupt control. 
R/W. Read/Write (input). This status signal 
indicates that the master CPU is executing a 
Read cycle if High, and a Write cycle if Low. 


WAIT. Wait (output, active Low, open-drain). 
When the CPU accesses the Z-UPC register 
file, this signal requests the master CPU to 
wait until the Z-UPC can complete its part of 
the transaction. 


P3l 


P36 


P21 


P26 


P2s 


P24 


P23 


P22 


P2l 


P20 


P33 


P34 


Pl1 


P16 


Pls 


P14 


P13 
Ph 
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Figure 3. Pin Assignments 
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AID. Address/Data (input). A Low on this pin 
defines information on the data bus as an 
address. A High defines the information 
as data. 


CS. Chip Select (input, active Low). A Low 
enables the UPC to accept address or data 
information from the master CPU during a 
write cycle or to transmit data to the master 
CPU during a read cycle. This line is usually 
generated from higher bits of the address 
,lines. 
DBo-DB.,. Data Bus (bidirectional). This bus is 
used to transfer address and data information 
between the master CPU and the UPC. 


Plo-PI7. P2o-P27. P30-P37' I/O Port Lines 
(bidirectional, TTL-compatible). These 24 lines 
are divided into three 8-bit I/O ports and may 
be configured in the following ways under pro- 
gram control: 
Plo-PI7' Port 1 (input/output-as output it can 
be push-pull or open-drain). Bit-programmable 
Parallel I/O. 


DATAl ~ 
~1~ 
BUS 
_ 
OB3 
-OB2 
-OBI 
-OBo 


TI:'~: { - 
AID 


AND RI!SI!T ~ 
Rli 
Z~:~O 


{ 


-Wli 


CONTROL 
- 
as 


WAIT 


{ 


iNT OR P3s 


MASTER 
_ 
INTACK OR P32 


INTERR~:~ 
- 
,lEI OR P30 
lEO OR P3l 


+5V_ 
PCLK_ 
GNO_ 


P1 


7 _) 
Ple_ 
P1e- 


P14 
PORT 1 
P13- 
P12- 


Pl1 
P10- 


P33 _} 


P34 
PORT 3 
P31_ 


P3s 


~igure 4. Z8590 UPC Pin Functions 


P2o-P27' Port 2 (input/output-as output, it can 
be push-pull or open-drain). Bit-programmable 
Parallel I/O. 
P30-P37' Port 3 (four inputs, four outputs). 
Parallel I/O, handshake control, tiqler I/O, or 
interrupt control. 


PCLK. Clock (input). TTL-compatible clock 
input, 4 MHz maximum. This signal does not 
need to be related to the master CPU clock. 
RD. Read (input, active Low). A Low enables 
the master, CPU to read information from the 
UPC. Raising the voltage on this pin above 
VDD will force the UPC into test mode. 


WAIT. Wait (output, active Low, open-drain). 
When the CPU accesses the UPC register file, 
this signal requests the master CPU to wait 
until the UPC can complete its part of the 
transaction. 


WH. Write (input, active Low). A Low on this 
pin enables the master CPU to write informa- 
tion to the UPC. A simultaneous Low on RD 
and WR resets the UPC. It is held in reset as 
long as WR is Low. 


+5V 


PCLK 


lEO OR P3l 


1 


Z8590 


UPC 


40 
P31 


39 
P3s 


38 
P2l 


37 
P2a 


38 
P2s 


35 
P24 


34 
P23 


33 
P22 


32 
P21 


31 
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30 
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P34 
Pll 


PIa 


PIS 
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Figure 5. Z8590 UPC Pin Assignments 
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Address Space. On the 40-pin UPC, all 
address space is committed to on-chip 
memory. There are 2048 bytes of mask- 
programmed ROM and 256 bytes of register 
file. I/O is memory-mapped to three registers 
in the register file. Only the Protopack version 
of the UPC can access external program 
memory. See the section entitled "Special 
Configurations" for a complete description of 
the Protopack version. 
Program Memory. Figure 6 is a map of the 2K 
on-chip program ROM. Even though the archi- 
tecture allows addresses from 0 to 4K, behav- 
ior of the device above program address 2047 
(7FFH) is not defined. The first 12 bytes of pro- 
gram memory are reserved for the UPC 
interrupt vectors. In the RAM version, ad- 
dresses OCH through 2FH are reserved for on- 
chip ROM. 


20 


LOCATION OF 
FIRST BYTE OF 
INSTRUCTION 
EXECUTED AFTER 
RESET 


47 


'I'-.. 


12 


11 


10 


9 


8 


7 


6 


5 


4 


3 


2 


1 


0 


USER 
ROM 


" 
IRQ5 LOWER BYTE 


IRQ5 UPPER BYTE 


IRQ4 LOWER BYTE 


IRQ4 UPPER BYTE 


IRQ3 LOWER BYTE 


IRQ3 UPPER BYTE 


IRQ2 LOWER BYTE 


IRQ2 UPPER BYTE 


IRQ1 LOWER BYTE 


IRQ1 UPPER BYTE 


IRQO LOWER BYTE 


IRQO UPPER BYTE 


Figure 6. Program Memory Map 


Register File. This 256-byte file includes three 
I/O port registers (1-3H), 234 general-purpose 
registers (6-EFH), and 19 control, status and 
special I/O registers (OH, 4H, 5H, and 
FO-FFH). The functions and mnemonics 
assigned to these register address locations 
are shown in Figure 7. Of the 256 UPC 
registers, 19 can be directly accessed by the 
master CPU; the others are accessed indirectly 
via the block transfer mechanism. 


LOCATION 


FFH 


FEH 


FDH 


FCH 


FBH 


FAH 


F9H 


F8H 


F7H 


F6H 


F5H 


F4H 


F3H 


F2H 


F1H 


FOH 


EFH 


6H 


5H 


4H 


3H 


2H 
lH 


OH 


STACK POINTER 


MASTER CPU INTERRUPT CONTROL 


REGISTER POINTER 


PROGRAM CONTROL FLAGS 


UPC INTERRUPT MASK REGISTER 


UPC INTERRUPT REQUEST REGISTER 


UPC INTERRUPT PRIORITY REGISTER 


PORT 1 MODE 


PORT 3 MODE 


PORT 2 MODE 


To PRESCALER 


TIMER/COUNTER 0 


Tl PRESCALER 


TIMER/COUNTER 1 


TIMER MODE 


MASTER CPU INTERRUPT VECTOR REG. 


GENERAL-PURPOSE REGISTERS 


DATA INDIRECTION REGISTER 


LIMIT COUNT REGISTER 


PORT 3 


PORT 2 


PORT 1 


DATA TRANSFER CONTROL REGISTER 


IDENTIFIER 
(UPC Side) 


SP 


MIC 


RP 


FLAGS 


IMR 


IRQ 


IPR 


P1M 


P3M 


P2M 


PREO 


To 


PRE1 


Tl 


TMR 


MIV 


DIND 


LC 


P3 


P2 


P1 


DTC 


Figure 7. Rogistor File Organization 
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The 1/0 port and control registers are 
included in the register file without differen- 
tiation. This allows any UPC instr~ction to 
process 1/0 or control information, thereby 
eliminating the need for special 1/0 and con- 
trol instructions. All general-purpose registers 
can function as accumulators, address 
pOinters, or index registers. In instruction exe- 
cution, the registers are read when they are 
defined as sources and written when defined as 
destinations. 


UPC instructions may access registers 
directly or indirectly using an 8-bit address 
mode or a 4-bit address mode and a Register 
Pointer. For the 4-bit addressing mode, the file 
is divided into 16 working register groups, 
each occupying 16 contiguous locations 
(Figure 8). The Register Pointer (RP) addresses 
the starting point of the active working-register 
group, and the 4-bit register designator sup- 
plied by the instruction specifies the register 
within the group. Any instruction altering the 
contents of the register file can also alter the 
Register Pointer .. The UPC instruction set has a 
special Set Register Pointer (SRP) instruction 
for initializing or altering the pointer contents. 


Stacks. An 8-bit Stack Pointer (SP), register 
R255, is used for addressin'g the stack, 
residing within the 234 general-purpose 
registers, address location 6H through EFH. 
PUSH and POP instructions can save and 
restore any register in the register file on the 
stack. During CALL instructions, .the Program 
Counter is automatically saved on the stack. 
During UPC interrupt cycles, the Program 
Counter and the Flag register are automati- 
cally saved on the stack. The RET and IRET 
instructions pop- the saved values of the Pro- 
gram Counter and Flag register. 


FFH 
FDH 
- 
(j 1 I 1 
o 0 0 0 
FOH 
EFH 
EOH 
DFH 
DOH 
CFH 
COH 
BFH 
BOH 
AFH 
AOH 
9FH 
90H 
8FH 


THE 4·BIT REGISTER} 
POINTER PROVIDES THE 
UPPER NIBBLE OF THE 


REGISTER FILE. ADDRESS 
FOR THE 4·BIT ADDRESS 
MODE. 


7SH 01110101 


80H 
~ 
70H 
6FH 
60H 
SFH 


{ '"' cow," """ 
OF THE REGISTER FILE 
ADDRESS (0101) IS 
PROVIDED BY THE 
INSTRUCTION. 


SOH 
4FH 
40H 
3FH 
30H 
2FH 
20H 
1FH 
10H 
OFH 


0 


Figure 8. Register Pointer Mechanism 
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Ports. The UPC has 24 lines dedicated to 
input and output. These are grouped into three 
ports of eight lines each and can be con- 
figured under software control as inputs, out- 
puts, or speCial control signals. They can be 
programmed to provide Parallel 1/0 with or 
without handshake and timing signals. All out- 
puts can have active pullups and pulldowns, 
compatible with TTL loads. In addition, Port 1 
and 2 may be configured as open-drain outputs. 


Port 1. Individual bits of Port 1 can be con- 
figured as input or output by programming 
Port I Mode register (PIM) F8H. This port is 
accessed by the UPC program as general 
register IH. It is written by specifying address 
IH as the destination of any instruction used to 
store data in the output register. The port is 
read by specifying address 1 H as the source of 
an instruction. 


Port 1 may be placed under handshake con- 
trol by programming Port 3 Mode register 
(P3M) F7H. This configures Port 3 pins P33 
and P34 as handshake control lines DA V} and 
RDYI for input handshake, or RDY} and DAV} 
for output handshake, as determined by the 
direction (input or output) assigned to bit 7 of 
Port 1. The Port 3 Mode register also has a bit 
that programs Port 1 for open-drain output. 
Port 2. Individual bits of Port 2 can be con- 
figured as inputs or outputs by programming 
Port 2 Mode register (P2M) F6H. This port is 
accessed by the UPC program as general 
register 2H, and its functions and methods of 
programming are the same as those of Port 1. 
Port 3 pins P31 and P36 are the handshak~ 
lines DA V 2 and RDY 2, with the direction (input 
or output) determined by the state of bit 7 of 
the port. The Port 3 Mode register also has a 
bit used to program Port 2 for open-drain 
output. 


Function 
Line Direction 
Signal 
{ 


P3l 
In 
DAV2/RDY2 


Handshake 
P33 
In 
DAVI/RDYI 


P34 
Out 
RDYl/DAVl 
P36 
Out 
RDY2/DAV2 


UPC Interrupt { 


P30 
In 
IRQ3 


Request· 
P3l 
In 
IRQ2 
P33 
In 
IRQl 
{ 
Counter/Timer 
P31 
In 
T7N 
P36 
Out 
TOUT 


{ 


P3S 
Out 
INT 


Master CPU 
P32 
In 
INTACK 


P30 
In 
lEI 
P37 
Out 
lEO 


Test Mode 
P3S 
Out 
AID 


·P30. P3l. and P33 can always be used as UPC interrupt 
request inputs. regardless of the configuration 
programmed. 


Table 1. Port 3 Control Functions 
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Functional 
Description 
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Port 3. This port can be configured as I/O or 
control lines by programming the Port 3 Mode 
register. Port 3 is accessed as general register 
3H. The directions of the eight data lines are 
fixed. Four lines, P30 through P33, are inputs, 
and the other four, P34 through P37, are out- 
puts. The control functions performed by Port 
3 are listed in Table] 


Counter/Timers. The UPC contains two 8-bit 
programmable counter/timers, each driven by 
an internal 6-bit programmable prescaler. 
The Tl prescaler can be driven by internal 
or external clock sources. The TO prescaler is 
driven by an internal clock source. Both 
counter/timers operate independently of the 
processor instruction sequence to relieve the 
program from time-critical operations like 
event counting or elapsed-time calculation. TO 
Prescaler register (PREO) F5H and Tl Pre- 
scaler register (PREl) F3H can be programmed 
to divide the input frequency of the source 
being counted by any number from 1 to 64. A 
Counter register (F2H or F4H) is loaded with a 
number from 1 to 256. The corresponding 
counter is decremented from this number each 
time the prescaler reaches end-of-count. When 
the count is complete, the counter issues a 
timer interrupt request; IRQ4 for TO or IRQs 
for Tl. Loading either counter with a number 
(n) results in the interruption of the UPC at the 
nth count. 


The counters can be started, stopped, 
restarted to continue, or restarted from the ini- 
tial value. They can be programmed to stop 
upon reaching end-of-count (Single-Pass 
mode) or to automatically reload the initial 
value and continue counting (Modulo-n Con- 
tinuous mode). The counters and prescalers 
can be read at any time without disturbing 
their values or changing their counts. The 
clock source for timer T 1 can be defined as 
anyone of the following: 


[J UPC internal clock (4 MHz maximum) 
divided by four. 


[] External clock input to Counter/Timer Tl 
via P3l (l MHz maximum). 


1:1 Retriggerable trigger input for the UPC 


internal clock divided by four. 


II Nonretriggerable trigger input for the UPC \ 


internal clock divided by fqur. 


I!I External gate input for the UPC internal 
clock divided by four. 


TO is driven by the UPC internal clock 
divided by four. 


Interrupts. The UPC allows six interrupts from 
eight different sources as follows: 


II Port 3 lines P30, P32, and P33. 


II The master CPU(3). 


iii The two counter/timers. 


These interrupts can be masked and globally 
enabled or disabled using Interrupt Mask 
Register (IMR) FBH. Interrupt Priority Register 
(IPR) F9H specifies the order of their priority. 
All UPC interrupts are vectored. 
Table 2 lists the UPC's interrupt sources, 
their types, and their vector locations in pro- 
gram ROM. Interrupt Request IRQo is 
dedicated to master CPU communications. 
Interrupt Requests IRQl, IRQ2, and IRQ3 are 
generated on the falling transitions of external 
inputs P33, P3l, and P30. Interrupt Requests 
IRQ4 and IRQs are generated upon the timeout 
of the UPC's two counter/timers. When an 
interrupt request is granted, the UPC enters an 
interrupt machine cycle. This cycle disables all 
subsequent interrupts, saves the Program 
Counter and Status Flags, and branches to the 
program memory vector location reserved for 
that interrupt. This memory location and the 
next byte contain the 16-bit address of the 
interrupt service routine for that particular 
interrupt request. 
The UPC also supports polled" systems. To, 


accommodate a polled structure, any or all of 
the interrupt inputs can be masked and the 
Interrupt Request register polled to determine 
which of the interrupt requests needs service. 
Following any hardware reset operation, an 
EI instruction must be executed to enable the 
setting of any interrupt request bit in the 
IRQ register. Interrupts must be disabled prior 
to changing the content of either the IPR 
(F9H) or the IMR (FBH). DI is the only instruc- 
tion that should be used to globally disable 
interrupts. 


Vector 
Name 
Source 
Location 
Comments 


IRQo 
EOM, XERR, LERR 
0,1 
Internal (RO Bits 0, 1, 2) 


IRQI 
DAVI, IRQI 
2,3 
External (P33) I Edge Triggered 


IRQ2 
DAV2, IRQ2' TIN 
4,S 
External (P31) I Edge Triggered 


IRQ3 
IRQ3' lEI 
6,7 
External (P30) I Edge Triggered 


IRQ4 
TO 
8,9 
Internal 


IRQ5 
Tl 
10,11 
Internal 


Table 2. Interrupt Types, Sources, and Vector Locations 
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Master CPU Register File Access. There are 
two ways in which the master CPU can access 
the UPC register file: direct access and block 
access. 


Direct Access. Three UPC registers-the Data 
Transfer Control (OH), the Master Interrupt 
Vector (FOH), and the Master Interrupt Control 
(FEH)-are mapped directly into the master 
CPU address space. The master CPU accesses 
these registers via the addresses shown in 
Table 3. 
The master CPU also has direct access to 16 
registers known as the DSC (Data, Status, 
Command) registers. The DSC registers are 
numbered 0 through F (DSCO-DSCF). These 
registers can be any 16 contiguous register file 
registers beginning on a 16-byte boundary. 
The base address of the DSC register group is 
designated by the IRP (I/O Register Pointer), 
which is bits D4-D7 of the Data Transfer Con- 
trol register (OH). Figure 9 shows how the 
register address is made up of the 4-bit IRP 
field, concatenated with the low order 4-bits of 
the address from the master CPU. 


Block Access. The master CPU may transmit 
or receive blocks of data via address xxxlO101. 
When the master CPU accesses this address, 
the UPC register pointed to by the Data 
Indirection register is read or written. The 


DTC REGISTER (OHI 


lAP 
~ 


ADDRESS FROM CPU 


I ATI A61 A51 A41 A31 A21 A, I Ao I 


I~~~'"'~'" 


I RTI R61 R51 R41 R31 R21 R, I Ro I 


REGISTER J.- 
FILE 


"The shift or no·shift state is set during a hardware reset. If the 
Wait line is held High during the hardware reset, the 8090/4 is in 
the shift state after the reset. If WAIT is held Low, it is in the no· 
shift state. The shift state is maintained until the next hardware 
reset. Figure 7 shows one way to interface the 8090/4 for the use 
of no·shift. 


Figure 9. DCS Register Addressing Scheme 


Data Indirection register is incremented, and 
the Limit Count register is decremented, for 
example, when the master CPU issues a read 
or write to address xxx10101 while the Data 
Indirection register contains the value 33H. 
The operation causes register 33H to be read 
or written and the Data Indirection register to 
be incremented to 34H. This scheme is well 
suited to Block I/O Instructions and allows the 
master CPU to efficiently read or write a block 
of data to or from the UPC. 


The Limit Count register (04H) is 
decremented and is used to control the 
number of bytes to be transferred by master 
CPU block accesses. If the master CPU 
attempts a read or write to the UPC after the 
Limit Count register reaches 6, the access is 
not completed, the LERR bit (D1) of the Data 
Transfer Control register is set (ihdicating a 
limit error), and the LERR error causes an 
IROo interrupt request. 
The IRP field of the Data Transfer Control 


register, the Data Indirection register, and the 
Limit Count register are not directly accessible 
to the master CPU and therefore must be set 
by the UPC. This allows the UPC to protect 
itself from master CPU errors and frees the 
master CPU from tracking the UPC's internal 
data layout. 


8090/4 
8590/4 
8090/4 
UPC Address 
No-Shift 
Shift 


Decimal 
Hex 
Identifier Address 
Address 


0 
OH 
DIC 
xxx 1 1000 
xx11000x 


5 
5H 
DIND 


@5** 
@5H** 
xxx 10 10 1 xxlOlOlx 


240 
FOH 
MIV 
xxx 10000 
xxlOOOOx 


254 
FEH 
MIC 
xxxllllO 
xxIII lOx 


*n 
DSCO 
xxxOOOOO 
xxOOOOOx 


n+l 
DSCI 
xxxOOOOI 
xxOOOOlx 


n+2 
DSC2 
xxxOO010 
xxOOOlOx 


n+3 
DSC3 
xxxOOO11 
xxOOOllx 


n+4 
DSC4 
xxxOOlOO 
xxOOlOOx 


n+5 
DSC5 
xxxOO 10 1 
xxOO 10 1 x 
n+6 
DSC6 
xxxOOllO 
xxOOllOx 


n+7 
DSC7 
xxx0011 1 xx00111x 


n+B 
DSCB 
xxxOlOOO 
xxOlOOOx 


n+9 
DSC9 
xxx01001 
xxOlO01x 


n+ 10 
DSCA xxxO 10 10 
xxOl 0 lOx 


n+ 11 
DSCB 
xxx01011 
xxOlOl1x 
n+ 12 
DSCC xxx01100 
xx01100x 


n+ 13 
DSCD xxx01101 
xxOl101x 
n+ 14 
DSCE 
xxx011 10 
xx01 1 lOx 


n+ 15 
DSCF 
xxx01111 
xx01111x 


x = don't care 
On is the value in the IRP x 16 
""Master CPU accesses the register address in Register 5. 


Table 3. Master CPU/UPC Register Map 
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The Protopack version of the UPC is iden- 
tical to the 40-pin ROM-based UPC with the 
following exceptions: 
c All but 36 bytes of internal ROM are omitted 
from the Protopack RAM/ROM version. 


• The memory address and data lines are buf- 
fered and brought out to the socket on the 
Protopack. This socket uses a 2Kx8 RAM or 
ROM. 


The Protopack version of the UPC allows the 
user to prototype the system in hardware with 
an actual UPC device and to develop the code 
intended to be mask programmed into the 
on-chip ROM of the 40-pin UPC for the pro- 
duction system. The Protopack version of the 
UPC is an extremely versatile part. RAM pro- 
gram memory can be used on the 40-pin Pro- 
topack with RAM/ROM for all but 36 bytes of 
the UPC's memory space. This memory can 
then be downloaded from the master CPU 
using a bootstrap program stored in the 36 
bytes (C-2F). Figure 10 is a memory map for 
the RAM version. This package will also ac- 
cept a ROM, provided that the area from C to 
2F is not used for programming. 


Using the Z8094/Z8594 with EPROM or 
RAM. The 28094 2-UPC and the 28594 UPC 
can be used with an EPROM or RAM plugged 
into the socket on top of the 40-pin package. 
Instructions for using a RAM are provided in 
. Chapter 8 of the UPG Technical Manual 
(document #00-2055-01). If an EPROM is used, 
the follOWing design considerations must be 
observed for proper operation: 


1. The pin-out for the EPROM is 2716 com- 
patible. 


2. Programs in the EPROM must begin at 30 


(hex). The RAM bootstrap ROM resides in 
locations OC (hex) to 2F (hex). 


FFFH ...-----------....... 
(7FFH 


PROGRAM MEMORY 
EXTERNAL 
RAM 


~~~~--------------------~ } 


BOOTSTRAP ROM 
INTERNAL 
ROM 


CH BH~----I} 
UPC INTERRUPT 
~ 
____ 
V_E_~_O_R_S_____ 
EXTERNAL RAM 


Figure 10. UPC RAM Version Memory Map 


3. The LDE instructions that would attempt a 
write to the EPROM cannot be used. 


4. The UPC must be taken out of the Download 
mode by the host CPU after a reset: This is 
accomplished by having the host CPU write 
two bytes to the UPC. The first byte must 
reset the Interrupt Pending bit (05) in the 
Master CPU Interrupt Control (MIC) 
register. The second byte must set the End 
of Message bit (DO) in the same register. 


Any static RAM that can be interchangeably 
used with a 2716 EPROM can be plugged into 
the Protopack socket. 


Protopaclc: Pin Functions. Forty of the pins on 
the Protopack versions have functions identical 
to those of the 40-pin version. The remaining 
24 pins have additional functions described 
below. (Figure 11 shows the Protopack ver- 
sions' pin functions and pin assignments.) 
Ao-Alo. Program Memory Address Lines (out- 
put). These lines are identical in all RAM/ROM 
versions in the Protopack. They are used to ad- 
. dress 2K bytes of external UPC memory. 


00-07. Program Data (input/output). Data is 
read in from the external memory on these'. 
lines. The RAM version also writes external 
memory through this bus. 


MOS. Memory Data Strobe (output, active 
Low). This signal is Low during an instruction 
fetch or memory write . 
MR/W. Memory Read/Write (output RAM ver- 
sions only). This signal is High when the UPC 
is fetching an instruction and Low when it is 
loading external memory. 


Z8094 
Z8594 


+5V 
+5V 1 


PCLK 
PCLK 2 


P37/1EO 
P37/1EO 3 


P3011EI 
P3011EI 4 


P3s1iNf 
P3s1iNf 5 


P32/1NTACK 
P32/1NTACK 6 


os 
RD7 


R/W 
WR 8 


AS 
A/o 9 


cs 
CS 10 


GND 
GND 11 


WAIT 
WAIT 12 


AD7 
DB7 13 


ADs 
DBs 14 


ADs 
DBs 15 


AD4 
DB4 16 


AD3 
DB3 17 


AD2 


ADI 
DBI 19 


ADo 
DBo 20 


'SOCKET FOR 2716 EPROM (2K )( 8) OR RAM 


Socket Pin Definition: 
pin 1 A7 
pin 9 Do 
pin 17 D7 
pin 2 As 
pin 10 Dl 
pin 18 MDS 


pin 3 As 
pin 11 D2 
Pin 19 Al0 


pin 4 A4 
pin 12 GND 
pin 20 GND 
pin 5 A3 
pin 13 D3 
pin 21 MR/W 
pin 6 A2 ' 
pin 14 D4 
pin 22 Ag 
pin 7 Al 
pin 15 Ds 
pin 23 As 


pin 8 Ao 
pin 16 Ds 
pin 24 +5 V 


Figure II. Z80941Z8594 UPC Protopack Pin Assignments 
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The following notation is used to describe the 
addressing modes and instruction operations as 
shoyvn in the instruction summary. 


IRR 
Indirect register pair or indirect working-register 
pair address 
Irr 
Indirect working-register pair only 
X , 
Indexed address 
DA 
Direct address 


dst 
src 
cc 


Destination location or contents 
Source location or contents 
Condition code (see list) 


@ 
Indirect address prefix 


SP 
Stack Pointer (control register FFH) 


PC 
Program Counter 


, FLAGS Flag register (control register FCH) 
RP 
Register Pointer (control register FDH) 
IMR 
Interrupt Mask register (control register FBH) 


Control Register FCH contains the folloWing six 
flags: 


C 
Carry flag 
Z 
Zero flag 


S 
Sign flag 


V 
Overflow flag 
D 
DeCimal-adjust flag 
H 
Half-carry flag 


RA 
1M 
R 


IR 


Ir 
RR 


Relative address 
Immediate 
Register or working-register address 
Working-register address only 
Indirect-register or indirect working-register 
address 
Indirect working-register address only 
Register pair or working-register pair address 


Assignment of a value is 'inqicated by the symbol 


"_". For example, 
dst - 
dst + src 
indicates that the source data is added to the 
destination data and the result is stored in the 
destination location. The notation "addr(n)" ,is used 
to refer ~o bit "nil of a given location. For example, 
dst (7) 
refers to bit 7 of the destination operand. 


Affected flags are indicated by: 
o 
Cleared to zero 
Set to one 
* 
Set or cleared according to operation 
Unaffected 


X 
Undefined 


Value 
Mnemonic 
Meaning 
Flags Set 


1000 
Always true 


0111 
C 
Carry 
C = 1 
1111 
NC 
No carry 
C = a 


0110 
Z 
Zero 
Z = 1 


1110 
NZ 
Not zero 
Z = a 


1101 
PL 
Plus 
S 
= a 


0101 
MI 
Minus 
S 
= 1 


0100 
OV 
Overflow 
V = 1 


1100 
NOV 
No overflow 
V =0 
0110 
EO 
Equal 
Z = 1 


1110 
NE 
Not equal 
Z = a 


1001 
GE 
Greater than or equal 
(S XOR V) = a 


0001 
LT 
Less than 
(S XOR V) = 1 


1010 
GT 
Greater than 
[ZOR (S XOR V)] = 0 
0010 
LE 
Less than or equal 
[ZOR (S XOR V)] = 1 
1111 
UGE 
Unsigned greater than or equal 
C=O 
a III 
ULT 
Unsigned less than 
C = 1 


1011 
UGT 
Unsigned greater than 
(C = 0 AND Z = 0) = 1 
0011 
ULE 
Unsigned less than or equal 
(C OR Z) = 1 


0000 
Never true 


Instruction 
Formats 


2037-013 


OPC 


dst 
OPC 


CCF, 01, EI, IRET, NOP, 
RCF, RET, SCF 


INCr 


One-Byte Instructions 


CLR, CPL, DA, DEC, 


'----=-="'------' OR 11 1 1 01 dsllsrc 1 ~~~~'~~~Rt~~:R:OP' 


OPC 
I 
i---""ds"";t---I OR 11 1 1 01 
dst 


OPC 
VALUE 


1-.---':'=:":""----' OR 11 1 1 01 


dst 
1 OPC 
VALUE 
I 
dSIlCCR~ OPC 


RRC, SRA, SWAP 


JP, CALL (Indirect) 


SRP 


ADC, ADD, AND, 
CP, OR, SBC, SUB, 
TCM, TM, XOR 


LD, LDE, LDEI, 
LDC, LOCI 


LD 


LD 


DJNZ, JR 


Two-Byte Instructions 


I---";;';":---i OR 11 1 101 
dst 


ADC, ADD, AND, CP, 
LD, OR, SBC, SUB, 
TCM, TM, XOR 


ADC, ADD, AND, CP, 
LD, OR, SBC, SUB, 
TCM, TM, XOR 


LD 


LD 


JP 


CALL 


Three-Byte Instructions 
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Opcode 
Map 


o 


2 


3 


" 


5 


M 
6 


II e 
II 
:Q 
7 


:9 
:z: .. 
II 
Il. 
8 
Il. 
~ 


9 


A 


B 


C 


0 


E 


o 


6,5 
DEC 


RI 


6,5 
RLC 


RI 
6,5 
INC 
RI 


8,0 
IP 
IRRI 


8,5 
OA 
RI 


10,5 
POP 
RI 


6,5 
COM 
RI 


10112,1 
PUSH 
Rz 


10,5 


PECW 


RRI 


6,5 
RL 
RI 


10,5 
INCW 


RRI 


6,5 
CLR 
RI 


6,5 
RRC 


RI 


6,5 
SRA 
RI 


6,5 
RR 
RI 


8,5 


F 
'SWAP 
RI 


\.. 


Bytes per- 
Instruction 


2 


6,5 
6,5 


DEC 
ADD 


IRI 
rl, rz 


6,5 
6,5 


RLC 
ADC 


IRI 
rl, rz 


6,5 
6,5 


INC 
SUB 
IRI 
rl, rz 


6,1 
6,5 
SRP 
SBC 


1M 
rl, fZ 


8,5 
6,5 
OA 
OR 
IRI 
rl, rz 


10,5 
6,5 
POP 
ANO 
IRI 
rl, rz 


6,5 
6,5 
COM 
TCM 


IRI 
rl, rz 


12/14,1 
6,5 
PUSH 
TM 


IRz 
rl, rz 


10,5 
12,0 
OECW 
LOE 
IRI 
rl, Irrz 


6,5 
.12,0 


RL 
LOE 


IRI 
rz,lrrl 


10,5 
6,5 


INCW 
CP 
IRI 
rl, rz 


6,5 
6,5 


CLR 
XOR 
IRI 
rl, rz 


6,5 
12,0 


RRC 
LOC 


IRI 
rl, Irrz 


6,5 
12,0 
SRA 
LOC 


IRI 
rz,lrrl 


6,5 
RR 
IRI 


8,5 
SWAP 
IRI 


V" 


2 


Execution 
Cycles 


Upper 
Opcode --.. A 
Nibble 


First 
Operand 


Lower Nibble (Hex) 


3 
" 


5 
6 


6,5 
10,5 
10,5 
10,5 
ADD 
ADD 
ADD 
ADD 


rl,lrz 
Rz,RI 
IRz,RI 
RI,IM 


6,5 
10,5 
10,5 
10,5 


ADC 
ADC 
ADC 
ADC 


rl,Irz 
R2,RI 
IRz,RI 
RI,IM 


6,5 
10,5 
10,5 
10,5 
SUB 
SUB 
SUB 
SUB 
rl,lrz 
Rz,RI 
IRz,RI 
RI,IM 


6,5 
10,5 
10,5 
10,5 


SBC 
SBC 
SBC 
SBC 
rl,lrz 
Rz,RI 
IRz,RI 
RI,IM 


6,5 
10,5 
10,5 
10,5 
OR 
OR 
OR 
OR 
rl,lrz 
Rz,RI 
IR2,RI 
RI,IM 


6,5 
10,5 
10,5 
10,5 
ANO 
ANO 
ANO 
ANO 
rl,lrz 
Rz,RI 
IRz,RI 
RI,IM 


6,5 
10,5 
10,5 
10,5 
TCM 
TCM 
TCM 
TCM 


rl,lrz 
Rz,RI 
IRz,RI 
RI,IM 


6,5 
10,5 
10,5 
10,5 


TM 
TM 
TM 
TM 


rl,lrz 
R2,RI 
IRz,RI 
RI,IM 


18,0 
LOEI 
IrI,lrrz 


18,0 
LDEI 
Irz, Irrl 


6,5 
10,5 
10,5 
10,5 
CP 
CP 
CP 
CP 
rl,lrz 
R2,RI 
IRz,RI 
RI,IM 


6,5 
10,5 
10,5 
10,5 
XOR 
XOR 
XOR 
XOR 
rl, Irz 
Rz,RI 
IRz,RI 
RI,IM 


18,0 
LOCI 
Irl,lrrz 


18,0 
20,0 
20,0 
LOCI 
CALL* 
CALL 


Irz, Irrl 
IRRI 
DA 


6,5 
10,5 
10,5 
10,5 
LO 
LO 
LO 
LO 


rl,lr2 
R2,RI 
1R2,RI 
RI,IM 


6,5 
10,5 
LO 
LO 
Irl, rz 
Rz,IRI 


.; \.. 
"" 
3 


Lower 
Opcode 
Nibble 
• 


Pipeline 
Cycles 


Mnemonic 


Second 
Operand 


7 


10,5 
ADD 
IRI,IM 


10,5 
ADC 
IRI,IM 


10,5 
SUB 
IRI,IM 


10,5 
SBC 
IRI,IM 


10,5 
OR 
IRI,IM 


10,5 
ANO 
IRI,IM 


10,5 
TCM 
IRI,IM 


10,5 
TM 


IRI,IM 


10,5 
CP 
IRI,IM 


10,5 
XOR 
IRI,IM 


10,5 
LO 


rl, x, Rz 


10,5 
LO 
rz, x, RI 


10,5 
LO 


IRI,IM 


..I 


8 
9 
A 
B 
C 
o 
E 
F 


6,5 
6,5 
12/10,5 
12/10,0 
6,5 
12/10,0 
6,5 
LO 
LO 
OJNZ 
JR 
LO 
JP 
INC 


n,R2 
r2,RI 
n,RA 
cc,RA 
rl,IM 
cc,DA 
rl 
f--- 


f--- 


f--- 


f--- 


f--- 


I---- 


f--- 


f--- 
6,1 
DI 


f--- 
6,1 
EI 


f--- 
14,0 
RET 
----- 
16,0 
IRET 
- 


6,5 
RCF 
- 


6,5 


. SCF 
f--- 
6,5 
CCF 


I---- 
6,0 
r 
NOP 


\.. ~--------~~~----------~~ ~ 
~ 


2 


Legend: 
R = 8-Bit Address 
r = 4-Bit Address 
RI or rl = Dst Address 
R2 or r2 = Src Address 


Sequence: 


3 


Opcode, First Operand, Second Operand 


Note: The blank areas are not defined. 


*2-byte instruction; fetch cycle appears as a 3-byte instruction. 
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8085-002 


Instruction 
Instruction 
Addr Mode 
Opcode Flags Affected 
Instruction 
Addr Modo Opcode Flags Affected 


Summary, 
and Oporatlon 
Byte 
and Operation 
Byte 
dst 
src 
(Hex) 
CZSVDH 
dst 
src 
(Hex) 
CZSVDH 


ADC dst,src 
(Note 1) 
10 
* * * * 0 * 
LDE dst,src 
r 
Irr 
82 
------ 
dst - dst -+ src + C 
dst - 
src 
Irr 
92 


ADD dst,src 
(Note 1) 
00 
* * * * 0 * 
LDEI dst,src 
.Ir 
Irr 
83 
------ 
dst - 
dst + src 
dst - 
src 
Irr 
Ir 
93 


AND dst,src 
(Note 1) 
r - r + 1; rr - rr + 1 
50 
* 0 - - 
dst - 
dst AND src 
NOP 
FF 
------ 


CALL dst 
DA 
D6 
------ 
OR dst,src 
(Note 1) 
40 
- 
* * 0 - - 


SP - 
SP - 2 
IRR 
D4 
dst - dst OR src 


@SP - PC; PC - dst 
POP dst 
R 
50 
------ 
CCF 
EF 
* - - - - - 
dst - 
@SP 
IR 
51 
C - 
NOTC 
SP - 
SP + 1 


CLR dst 
R 
BO 
------ 
PUSH src 
R 
70 
------ 
dst - 
0 
IR 
Bl 
SP - SP-l; @SP - src 
IR 
71 


COM dst 
R 
60 
- 
* * 0 - - 
RCF 
CF 
0- - 
- - - 


dst - 
NOT dst 
IR 
61 
C-O 


CP dst,src 
(Note 1) 
AD 
* * * * - - 
RET 
AF 
------ 
N 


dst - src 
PC - 
@ SP; SP - SP + 2 
00 " 


DA dst 
R 
40 
RL dst ~ 
R 
90 
* X- - 
IR 
91 
CD 


dst - 
DA dst 
IR 
41 
~ 


DEC dst 
R 
00 
- * * * -- 
RLC dst Lri'l=E:i}J R' 
10 
~ 


dst-dst-1 
IR 
01 


c 
, 
• 
IR 
11 
I 
RR dst lElLJ, 
.tJ I~ 
EO 
DECW dst 
RR 
80 
- * * *-- 
El 
a. 


'dst - 
dst - 1 
IR 
81 
a 
RRC dst Lri'l=E:i}J R 
CO 
* * * 
DI 
8F 
------ 
Cl 
IMR (7) - 
0 


c 
, 
• 
IR 
en 
U) 
SBC dst,src 
(Note 1) 
3D 
* 1 * 
C 
DJNZ r,dst 
RA 
rA 
------ 
dst - dst - src - C 
- 
r - 
r - 1 
r=O-F 
.. 


if r :;t: 0 
SCF 
DF 
1 - - 
- - - 
c:I 
PC - 
PC + dst 
C-1 
IU 
Range: + 127, -128 
SRA dst lEl C2J . tJ I~ 


DO 
***0-- 
n 


EI 
9F 
------ 
Dl 
1MR (7) - 
1 
SRP src 
1m 
31 
------ 
INC dst 
rE 
-***-- 
RP - 
src 
dst - 
dst + 1 
r=O-F 
SUB dst,src 
(Note 1) 
20 
* * 1 * 
R 
20 
dst - dst - src 
IR 
21 


SWAP dst ® 
R 
FO 
X * * X - 
- 
INCW dst 
RR 
AO 
-***-- 
IR 
Fl 
dst - 
dst + 
IR 
Al 
TCM dst,src 
(Note 1) 
60 
- 
* * 0 - - 
IRET 
BF 
* * * * * * 
(NOT dst) AND src 


FLAGS - 
@SP; SP - SP + 1 
TM dst,src 
70 
PC - @SP; SP - SP + 2; IMR(7) -1 
(Note 1) 
- 
* * 0 - 
- 
dst AND src 
JP cc,dst 
DA 
cD 
------ 
if cc is true 
c=O-F 
XOR dst,src 
(Note 1) 
BO 
-**0-- 


PC - 
dst 
IRR' 
30 
dst - dst XOR src 
m cc,dst 
RA 
cB 
------ 
Note 1 
if cc is true, 
c=O-F 
These instructions have an identical set of addressing 
PC - PC + dst 


RaQge: + 127, -128 
modes, which ate encoded for brevity. The first opcode 
nibble is found' in lhe instruction set table above. The 
LD dst,src 
1M 
rC 
------ 
second nibble is expressed symbolically by a 0 in this 
dst - 
src 
r 
R 
r8 
table, and its value is found in the folloWing table to the 
R 
r9 
left of the applicable addressing mode pair. 
r=O-F 
For example, to determine the opcode of an ADC 
r 
X 
C7 
instruction using the addressing modes r (destination) and 
X 
r 
D7 
Ir (source) is 13. 
r 
Ir 
E3 
Ir 
r 
F3 
Addr Mode 
,R 
R 
E4 
Lower 
R 
1R 
E5 
dst 
src 
Opcode Nibble 
R 
1M 
E6 
IR 
1M 
E7 
[lJ 


IR 
R 
F5 
Ir 
[I] 


LDC dst,src 
r 
Irr 
C2 
------ 
R 
R 
rn 
dst - 
src 
Irr 
D2 
R 
IR 
@] 


LOCI dst,src 
Ir 
Irr 
C3 
------ 
R 
1M 
@] 
dst - 
src 
Irr 
Ir 
D3 
r - r + 1; rr - rr + 1 
IR 
1M 
[l] 
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Registers 


576 


R248 PIM 


Port 1 Mode Register 


UPC register address (Hex): Fa 


I~I~I~I~I~I~I~I~I 


R247 P3M 
Port 3 Mode Register 


UPC register address (Hex): F7 


I~I~I~I~I~I~I~I~I 


P10-P1r 1/0 DEFINITION 
'------ 0 DEFINES BIT AS OUTPUT 


1 DEFINES BIT AS INPUT 


R246 P2M 
Port 2 Mode Register 


UPC register address (Hex): F6 


III ~ : :::: ::~~::: ::~::: 
1 PORT 1 PULL·UPS ACTIVE 


o P35 = OUTPUT 
1 P35 = [NT 
RESERVED 
o P33 = INPUT 
P34 = OUTPUT 


1 P33 .. DAV1/R,DY1 
P34 = RDY1/DAV1 


I~I~I~I~I~I~I~I~I 
'-------- ~ ~!: ~ ~:~R~~~ ~!:: ~~~~~OUT) 


P2o-P27 1/0 DEFINITION 
'------ 0 DEFINES BIT AS OUTPUT 


1 DEFINES BIT AS INPUT 
'---______ ~ ~: ~ :~tUT 
~!~ : ~~TPUT 


R251lMR 
Interrupt Mask Register 


UPC register address (Hex); FB 


I~I~I~I~I~I~I~I~I 


'---------- ~ ~!~ : :~~~~K 


Figure 12. Port Mode Registers 


R250 IRQ 
Interrupt Request Register 


UPC register address (Hex); FA 


I~I~I~I~I~I~I~I~I 


~~~ 


L.1ENABLESIRQO 
L 
1 ENABLES IRQ1 


1 ENABLES IRQ2 


1 ENABLES IRQ3 


1 ENABLES IRQ4 


1 ENABLES IRQS 


RESERVED 


III'.~ ::::: ;~~:::~'" OOMM"'CA"O" 


IRQ2 = P31 INPUT 


IRQ3 = P30 INPUT 


IRQ4 = To 


- 
IROS = TI 
L-_______ RESERVED 
'--------- 1 ENABLES INTERRUPTS 


R2491PR 
Interrupt Priority Register 


UPC register address (Hex): F9 (Write Only) 


I~I~I~I~I~I~I~I~I 


o = IRQ1 > IRQ4 
INTERRUPT GROUP PRIORITY 
1 = IRQ4 > IRQ1 
.","m :::J II I 4 '"". '"0"""'''' ( •• 0""1 


RESERVED .. 000 


C>A> B = 001 
IRQO, IRQ2 PRIORITY (GROUP B) 
A>B>C - 
010 
0 = IRQ2 > IROO 


A>C>B = 011 
1 = IRQO>IRQ2 


B>C>A = 100 
C>B>A = 101 
IRQ3, IRQS PRIORITY (GROUP A) 
B>A>C = 110 
0 = IRQS > IRQ3 
RESERVED = 111 
1 .. IRQ3>IRQS 


Figure 13. Interrupt Control Registers 


R254 MIC 
R240 MIV 
Master CPU Interrupt Control Register 


UPC register address (Hex); FE 
Master CPU Interrupt Vector Register 


OPC register address (Hex); FO 


I~I~I~I~I~I~I~I~I 
I~I~I~I~I~I~I~I~I 


1 END OF MESSAGE 
~~ 


LO- 
L-I 
- 
_ _ VECTOR DATA (Do = LSB) 


o WAIT ENABLE WHEN WRITE 
1 WAIT DISABLE WHEN WRITE 
o ENABLE LOWER CHAIN 
1 DISABLE LOWER CHAIN 


o DISABLE DATA TRANSFER 
1 ENABLE DATA TRANSFER 


o VECTOR OUTPUT 
1 NO VECTOR OUTPUT 
'-------- ~ ~~S~~~T~:u~~~~~1~~~U:iN~~~gING 
'--..,------ ~ ~~~~1~~~U~~DUE~D::R~~~~ICE 
'---------- ~ :~~~==~~~ =~g~m ~~:BBLL:g 


Figure 14. Master CPU Interrupt Registers' 


20l7c009, OlD, all 


Registers 
(Continued) 


2017-012, 014, 013 


R252 FLAGS 
Flag Regi!;ter 
UPC register address (Hex); FC 


I~I~I~I~I~I~I~I~I 


~~llli 


L USER FLAG Fl 
L 
USER FLAG F2 


HALF CARRY FLAG 


DECIMAL ADJUST FLAG 


OVERFLOW FLAG 


SIGN FLAG 


ZERO FLAG 


'---------- CARRY FLAG 


R253 RP 
Register Pointer 
UPC register address (Hex); FD 


I~I~I~I~I~I~I~I~I 


REGISTER POINTER =:=J 


('4-'7) 
c= DON'T CARE 


R255 SP 
StacIe Pointer 
UPC register address (Hex); FF 


I~I~I~I~I~I~I~I~I 
I 
STACK POINTER 
(SPO-SP7) 


Figura 15. UPC Control Rogistors 


RODTC 


Data Transfer Control Register 
UPC register address (Hex); 00 


I~I~I~I~I~I~I~I~I 
~ 


(EOM)~ 


(LERR) 
0 
1 


(XERR) 


(EDX) 


END OF MESSAGE 


NO LIMIT ERROR 
LIMIT ERROR 


NO TRANSFER ERROR 
TRANSFER ERROR 


DISABLE DATA TRANSFER 
ENABLE DATA TRANSFER 


,",(I.;.;;RP~) _______ 1 1/0 REGISTER POINTER 


R4LC 
Limit Count Register 


UPC register address (Hex); 04 


I~I~I~I~I~I~I~I~I 


LIMIT COUNT VALUE 
L-. _____ (RANGE: 0-255 DECIMAL 
OO-FF HEX) 


R5 DIHD 


Data Indirection Register 


UPC register address (Hex): 05 


I~I~I~I~I~I~I~I~I 


IL-. _____ :~~':~~~)ON ADDRESS 


Figuro 16. Mastor CPU-UPC Data Transfer Rogistors 


R241 TMR 
Timer Mode Register 


UPC register address (Hex): F 1 


I~I~I~I~I~I~I~'~I 


TOUTMODESJ ug~ - 
RESERVED = 00 
0 = NO FUNCTION 


To OUT = 01 
1 = LOAD To 


Tl OUT = 10 
INTERNAL CLOCK OUT = 11 
0 = DISABLE To COUNT 
1 = ENABLE To COUNT 


. 
EXTERJJ..1 ~~g~~ 
0 = NO FUNCTION 
INPUT = 00 
1 = LOAD Tl 


TRI~~i~ :~~~~ ~ ~~ 
0 = DISABLE T 1 COUNT 
(NON.RETRIGGERABLE) 
1 = ENABLE Tl COUNT 


TRIGGER INPUT = 11 
(RETRIGGERABLE) 


R242 TI 


Counter/Timer I Register 


UPC register address (Hex); F2 


Tl INITIAL VALUE 
L-. ____ (RANGE: 1-256 DECIMAL 
01-00 HEX) 


R243 PREI 


Prescaler I Register 


UPC register address (Hex): F3 


1~'~'~'~'~'~f~'~1 l 


g~U~I\~N°J>L~ PASS 
1 = Tl MODULO. N 


CLOCK SOURCE 
o = EXTERNAL TIMING INPUT 
(TIN) MODE 
1 = Tl INTERNAL 


PRESCALER MODULO 
'------- (RANGE: 1-64 DECIMAL· 
01-00 HEX) 


R244 TO 


Counter/Timer 0 Register 


UPC register address (Hex): F4 


I~I~I~I~I~I~I~I~I 


I'------l~~~~~~~-~~~~~CIMAL 
01-00 HEX) 


R245 PREO 


Prescaler 0 Register 


UPC register address (Hex): F5 


I~I~I~I~I~I~I~I~I 
~L: 


COUNT MODE 


. 
0 = To SINGLE·PASS 
1 = To MODULO· N 


RESERVED 


PRESCALER MODULO 
(RANGE: 1-64 DECIMAL 
01-00 HEX) 


FigurQ 17. UPC CountorlTimor Rogistors 
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Registers 
Control Register 
0, 
Ds 
DS 
D" 
D3 
D2 
Dl 
DO 
Comments 
(Continued) 


DOH 
X 
X 
X 
X 
0 
0 
0 
0 
Disable data transfer 
Data Transfer Control Register 
from master CPU 


04H 
Not Defined 
Limit Count Register 


05H 
Not Defined 
Data Indirection Register 


FOH 
Not Defined 
Interrupt Vector Register 


FIH 
0 
0 
0 
0 
0 
0 
0 
0 
Stops TO and T 1 
Timer Mode 


F2H 
Not Defined 


TO Register 


F3H 
X 
X 
X 
X 
X 
X 
0 
0 
Single-Pass mode 


TO Prescaler 


F4H 
Not Defined 
Tl Register 


F5H 
X 
X 
X 
X 
X 
X 
0 
0 
Single-Pass mode 
Tl Prescale~ 
External clock source 


F6H 
Port 2 llnes defined as 


Port 2 Mode 
inputs 


F7H 
0 
0 
0 
0 
X 
0 
0 
Port 1. 2 open drain; 


Port 3 Mode 
P3S = INT; P30. P3!. P32. 
P33 defined as input; P34. 
P36. P37 defined as output. 


F8H 
' 1 
Port 1 lines defined as 


Port 1 Mode 
inputs 


F9H 
Not Defined 
Interrupt Priority 


FAH 
X 
X 
0 
0 
0 
0 
0 
0 
Reset Interrupt Request 
Interrupt Request 


FBH 
0 
X 
X 
X 
X 
X 
X 
X 
Interrupts disabled 
Interrupt Mask 


FCH 
Not Defined 
Flag Register 


FDH 
Not Defined 
Register Pointer 


FEH 
0 
0 
0 
0 
0 
0 
0 
0 
Master CPU interrupt dis- 
Master CPU Interrupt 
abled; wait enable when 
Control Register 
write; lower chain enabled 


FFH 
Not Defined 


Stack Pointer 


NOTE: X means not defined. 


Tablo 4. Control Register Reset Conditions 
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Absolute 
Maximum 
Ratings 


Standard 
Test 
Conditions 


DC 
Charac- 
teristics 


8085-006, 312 


V oltages on all pins 
with respect to GND .......... -0.5 V to + 7.0 V 
Operating Ambient 
Temperature ........ See Ordering Information 
Storage Temperature ........ -65°C to + 150°C 


The characteristics below apply for the 
following standard test conditions, unless 
otherwise noted. All voltages are referenced to 
GND. Positive current flows into the reference 
pin. Standard conditions are as follows: 


+5V 


2.2K 


-= 


Figuro lB. Tost Load 1 


Symbol 
Parameter 
Min 
Max 


VeH 
Clock Input High Voltage 
2.4 
Vee 


VeL 
Clock Input Low Voltage 
-0.3 
0.8 


VIH 
Input High Voltage 
2.0 
Vee 


VIL 
Input Low Voltage 
-0.3 
0.8 


VOH 
Output High Voltage 
2.4 


VOL 
Output Low Voltage 
0.4 


IlL 
Input Leakage 
-10 
10 


IOL 
Output Leakage 
-10 
10 


lee 
Vee Supply Current 
180 


Stresses greater than those listed under Absolute Maxi- 
mum Ratings may cause permanent damage to the device. 
This is a stress rating only; operation of the device at any 
condition above those indicated in the operational sections 
of these specifications is not implied. Exposure to absolute 
maximum rating conditions for extended periods may affect 
device reliability. 


D 4.75 V:s; Vee:S; +5.25 V 
o V SS = GND = a V 


D O°C :s; TA :s; +70°C* 


'See Ordering Information section for package 
temperature range and product number. 


Unit 


V 


V 


V 


V 


V 


V 


/LA 


/LA 


rnA 


+5V 


Figuro 19. Tost Load 2 


Condition 


IOH = -250/LA 


loL = +2.0 rnA 
o :5 VIN :5 +5.25 V 
o :5 VIN :5 +5.25V 


18K 


Notes 


2 


1. For AO-All' DO-D7, and MRlW on the Protopack versions, IOH = 100 "A and IOL = 1.0 rnA. 
2. For Protopack versions, lee = 180 rnA plus the current for the memory Ie used. 
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Master CPU 
Interface 
Timing 
Z8590/94 
PCLK 


AID 


cs 


DBa-DD7 
WRITE CASE 


WR 


DBo-DD7 
READ CASE 


iii) 


WAIT 


Interrupt 
Acknow ledge 
DBa-DD7 


Timing 
Z8590/94 
mTACr.: 


iiD 


lEI 


lEO 
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4MHz 
6MHz** 
No. 
Symbol" 
Parameter 
Min 
Max 
Min 
Max 
Notes*t 


1 
TrC 
Clock Rise Time 
20 
15 


2 
TwCH 
Clock High Width 
105 
1855 
70 
1855 


3 
TfC 
Clock Fall Time 
20 
10 


4 
TwCl 
Clock Low Width 
105 
1855 
70 
1855 


5 
TpC 
Clock Period 
250 
2000 
165 
2000 


6-TsND(WR) -- AID to WR I Setup Time 
80 
80 


7 
TsND(RD) 
AID to RD I Setup Time 
80 
80 


8 
ThND(WR) 
AID to WR t Hold Time 
30 
25 


9 
ThND(RD) 
AID to RD t Hold Time 
30 
25 


10 
TsCSf(WR) 
CS I to WR I Setup Time 
0 
0 


ll-TsCSf(RD) -- CS I to RD I Setup Time 
0 
0 


12 
TsCSr(WR) 
CS t to WR I Setup Time 
60 
60 


13 
TsCSr(RD) 
CS t to RD I Setup Time 
60 
60 
N 


14 
ThCS(WR) 
CS to WR I Hold Time 
0 
0 
00 


15 
ThCS(RD) 
CS to RD I Hold Time 
0 
0 
0 
CI) 


16-TsDI(WR) -- Data in to WR I Setup Time 
0 
0 
~ .. 


17 
Tw(WR) 
WR Low Width 
390 
250 
g 


18 
Tw(RD) 
RD Low Width 
390 
250 
D- 


19 
ThWR(DI) 
Data in to WR t Hold Time 
0 
0 
t.1 
20 
TdRD(DI) 
Data Valid from RD I Delay 
en 


21 -ThRD(DI) -- Data Valid to RD t Hold Time 
0 
0 
CoO 
52 
22 
TdRD(DIz) 
Data Bus Float Delay from RD t 
70 
45 
• 
23 
TdRD(DBA) 
RD I to Read Data Active Delay 
0 
0 
c:I 


24 
TdWR(W) 
WR I to WAIT I Delay 
150 
150 
• " 
25 
TdRD(W) 
RD I to WAIT I Delay 
150 
150 


26-TdDI(W) ---Data Valid to WAIT t Delay 
0 
0 


27 
TsAC~(RD) 
INTACK I to RD I Setup Time 
90 
80 
2 


28 
TdRD(DI) 
RD I to" Vector Valid Delay 
255 
180 


29 
ThRD(ACK) 
RD t to INTACK t Hold Time 
0 
0 


30 
ThIEI(RD) 
IEI to RD t Hold Time 
100 
100 


31- TwRDl 
RD (Acknowledge) Low Width 
255 
250 


32 
TdIEI(IEO) 
IEI to IEO Delay 
120 
100 


33 
TsIEI(RD) 
IEI to RD I Setup Time 
150 
120 


34 
TdACKf(IEO) 
IN TACK I to IEO I Delay 
250 
250 


35 
TdADKr(IEO) 
INTACK t to IEO t Delay 
250 
250 


NOTES: 
1. This parameter Is dependent on the state of the UPC at the time 
4. All output ac parameters use test load 1. 
of master CPU access. 
*Timlngs are preliminary and subject to change. 
2. In case where daisy chain is not used. 
tUnits In nanoseconds (ns). 
3. The timing characteristics given reference 2.0 V as High and 
**Z8590 only. 


0.8 V as Low. 
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Handshake 
Timing 


Reset 
Timing 


RAM Version 
Program 
Memory 
Timing 
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DATA IN 


DAV 
INPUT 


RDY 


OUTPUT 


DATA OUT 


DAV 
OUTPUT 


RDY 


INPUT 


MAS· 


Input Handshake 


DATA OUT VALID 


Output Handshake 


PORT 
READ 


I 
I 


~ 


MNW ----------~r_+_----------------------~--~ ,------------ 


(RAM VERSION 
ONLy) 


MDS 
WRITE CASE 


DO-D7 
WRITE CASE 


MDS 


READ CASE 


DO-D7 


READ CASE 
®>---...., .. 
~I 
SYNC.=S:Jj 


IRQN 
~~--~~--~----------------------------------- 


'This signal is not available externally. 


2017·017,018 2014·024 2017.019. 


4MHz 
6MHz** 


No. 
Symbol 
Parameter 
Min 
Max 
Min 
Max 
Notes*t 


TsDI(DA) 
Data in Setup Time 
0 
0 


2 
ThDA(DI) 
Data in Hold Time 
230 
230 


3 
TwDA 
Data Available Width 
175 
175 
1,2 
4-TdDAL(RY)--Data Available Low to Ready 
20-' -175---20--175 
1,2- 
Delay Time 
0 
0 
2,3 
5 
TdDAH(RY) 
Data Available High to Ready 
150 
150 
1,2 
Delay Time 
0 
0 
2,3 


6 
TdDO(DA) 
Data O~t to Data Available Delay Time 
50 
50 
2 
7 
TdRY(DA) 
Ready to Data Available Delay Time 
0 
205 
0 
205 
2 


4 MHz 
6MHz** 


No. 
Symbol 
Parameter 
Min 
Max 
Min 
Max 
Notes*t 


1 
TdRDQ(WR) 
Delay from RD t to WR 1 for No Reset 
40 
35 


2 
TdWRQ(RD) 
Delay from WR t to RD 1 for No Reset 
50 
35 


3 
TwRES 
Minimum Width of WR and RD both Low for Reset 
250 
250 
4 


4MHz 
6MHz** 


No. 
Symbol 
Parameter 
Min 
Max 
Min 
Max 
Notes*t 


1 
TwMAS 
Memory Address Strobe Width 
60 
55 
5 


2 
TdA(MAS) 
Address Valid to Memory Address Strobe t Delay 
30 
30 
5 


3 
TdMRIW(MAS) 
Memory ReadlWrite to Memory Address Strobe t 
Delay 
30 
30 
5 
4 
TdMDS(A) 
Memory Data Strobe t to Address Change Delay 
60 
60 


5 -TdMDS(MRIW)- Memory Data Strobe t to Memory ReadlWrite Not 
Valid Delay 
80 
75 


6 
Tw(MDS) 
Memory Data Strobe Width (Write Case) 
160 
110 
6 
7 
TdDO(MDS) 
Data Out Valid to Memory Data Strobe I Delay 
30 
30 
5 
8 
TdMDS(DO) 
Memory Data Strobe t to Data Out Change Delay 
30 
30 
5 
9 
Tw(MDS) 
Memory Data Strobe Width (Read Case) 
230 
230 
6 
lO-TdMDS(DI)--Memory Data Strobe I to Data In Valid Delay 
160 
130 
7- 


11 
TdMAS(DI) 
Memory Address Strobe t to Data In Valid Delay 
280 
220 
7 


12 
ThMDS(DI) 
Memory Data Strobe t to Data In Hold Time 
0 
0 


13 
TwSY 
Instruction Sync Out Width' 
160 
100 


14 
TdSY(MDS) 
Instruction Sync Out to Memory Data Strobe Delay 
200 
160 


15 
TwI 
Interrupt Request via Port 3 Input' Width 


NOTES: 
1. Input Handshake. 
2. Test Load 1. 
3. Output Handshake. 
4. Internal reset signal is Y2 to 2 clock delays from external reset 
condition. 
S. Delay times are specified for an input clock frequency of 4 
MHz. When operating at a lower frequency, the increase in in· 
put clock period must be added to the specified delay time, 


6. Data strobe width is specified for an input clock frequency of 4 
MHz. When operating at a lower frequency. the increase in 


100 
100 


three input clock periods must be added to the specified width. 
Data strobe width varies according to the instruction being ex- 
ecuted. 
7. Address strobe and data strobe to data in valid delay times 
represent memory system access times and are given for a 4 
MHz input frequency. 
* All timing references assume 2.0 V for a logic "1" and 0.8 V for a 
logic "0". All output ae parameters use test load 2. Timings are 
preliminary and subject to change. 
tUnits in nanoseconds (ns). 
* *Z8090 only. 
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N 
C» 
0 
CG 
@ ... 
DJ 
1:1 
D. 
II 
en 
t.D 
S! .. 
d .. 
8 


Master CPU 
Interface 
Timing 
Z8090/94 


Interrupt 
Acknow ledge 
Timing 
Z8090/94 
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peLK 


ADo-AD? 


MASTER CPU 
READ 


Ai 


RlW 


(WRITE) ....:.------~rl------~~+-----T--T----i- 


ruW 


(READ) -------~H_---- 


ADO-AD? 


MASTE~~I~~ ______ 
01 "_+-~';';;;"_"'I ~ _______ -+:::-:-_____ _ 


ADO-AD? 


61 


lEI 


lEO 


INT --------------------- 


2017-015,016 


4 MHz 
6MHz** 
No. 
Symbol 
Parameter 
Min 
Max 
Min 
Max 
No~es*t 


TrC 
Clock Rise Time 
20 
15 
2 
TwCh 
Clock High Width 
105 
1855 
70 
1855 
3 
TfC 
Clock Fall Time 
20 
10 
4 
TwCl 
Clock Low Width 
105 
1855 
70 
1855 
5-TpC 
Clock Period 
250-2000 
165 -2000 


6 
TsCS(AS) 
CS to AS t Setup Time 
0 
0 


7 
ThCS(AS) 
CS to AS t Hold Time 
60 
40 


8 
TsA(AS) 
Address to AS t Setup Time 
30 
10 


9 
ThA(AS) 
Address to AS t Hold Time 
50 
30 


lO-TwAS 
AS Low Width 
70 
50 


11 
TdDS(DR) 
DS t to Read Data Not Valid 
0 
0 


12 
TdDS(DRz) 
DS t to Read Data Float Delay 
70 
45 
2 


13 
TdAS(DS) 
AS t to DS 1 Delay 
60 
2095 
40 
2095 
N 


14 
TdDS(AS) 
DS t to AS 1 Delay 
50 
35 
CO 
C 


15-ThDW(DS)-- Write Data to 158t Hold Time 
30 
20 
1--- 
U) 
C 


16 
TdDS(DR) 
DS 1 to Read Data Valid Delay 
3 
- 
~ 


17 
TdAz(DS) 
Address Float to DS De~ay 
0 
0 
g 


18 
TwDS 
DS Low Width 
390 
250 
D- 


19 
TsRWR(DS) 
R!W (Read) to DS 1 Setup Time 
100 
80 
a 


20-TsRWW(DS)-- RlW (Write) to DS 1 Setup Time 
0 
0 
en 
to 


21 
TsDW(DSf) 
Write Data to DS 1 Setup Time 
30 
20 
~ 


22 
TdAS(W) 
AS t to WAIT 1· Valid Delay 
195 
160 
~ 
d 
23 
ThRW(DS) 
R!W to DS t Hold Time 
60 
40 
~ 


24 
TsDR(W) 
Read Data Valid to WAIT t 
0 
0 
6 


25 
TsIA(AS) 
IN TACK to AS t Setup Time 
0 
0 


26 
ThIA(AS) 
INTACK to AS t Hold Time 
250 
250 


27 
TdAS(DSA) 
AS t to DSI (lAcknowledge) Delay 
940 
200 


28 
TdDSA(DR) 
DS 1 (Acknowledge) to Read Data Valid 
360 
180 


Delay 


29 
TwDSA 
DS 1 (Acknowledge) Low Width 
475 
250 
30-TdAS(IEO)-- AS t to lEO Delay 
290 
250 


31 
TdIEIf(IEO) 
lEI to lEO Delay 
120 
100 


32 
TsIEI(DSA) 
IEI to DS 1 (Acknowledge) Setup Time 
150 
120 


33 
TdDS(lNT) 
DS 1 to INT Delay 
500 
500 


34 
ThIEI(DS) 
lEI to DS t Hold Time 
100 
100 


NOTES: 
l. Parameter does not apply to Interrupt Acknowledge trans- 
* Timings are preliminary and pubject change. 
actions. 
t Units)n nanoseconds (ns). 
2. The maximum value for TdAS(DS) does not apply to Interrupt 
* *Z8090 only. 
Acknowledge transactions. 
The timing characteristics given reference 2.0 V as High and 
3. This parameter is dependent on the state of UPC at the time of 
0.8 V as Low. 
master CPU access. 
All output ac parameters use test load I. 
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Product 
Package/ 
Product 
Package/ 


Number 
Temp 
Speed 
Description 
Number 
Temp 
Speed 
Description 


Z8590 
CS 
4.0 MHz 
UPC (40-pin) 
28090 
PS 
4.0 MHz 
UPC (40-pin) 


Z8090 
CS 
4.0 MHz 
Same as above 
28590-6 
PS 
6.0 MHz 
Same as above 


Z8590-6 
CS 
6.0 MHz 
Same as above 
28090-6 
PS 
6.0 MHz 
Same as above 


Z8090-6 
CS 
6.0 MHz 
Same as above 
28594 
RS 
4.0 MHz 
UPC Protopack 


Z8590 
PS 
4.0 MHz 
Same as above 
28094 
RS 
4.0 MHz 
Same as above 


NOTES: C = Ceramic, P = Plastic, R = Protopack; S = O°C to +70°C. 
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Zili©g 


Pioneering the 
Micro world 


",. 


The advancing demands of the 
marketplace have caught many 
design projects between the need 
for new features and the desire to 
preserve existing software. The 
l800 family provides the most 
desired new features without com- 
promise. It is totally software- (ob- 
ject code) compatible with the 
l80®. 


Memory Management. The de- 
mand for memory expanded 
beyond 64K is satisfied by the 
memory management of the l800, 
which also provides protection and 
dynamic relocation. Two alter- 
natives, 512K bytes and 16M bytes 
of physical address space, are 
available with MPUs in 40- and 
64-pin packages, respectively. The 
implementation deals with 4K or 
8K pages, which can be individu- 
ally mapped and protected. Virtual 
memory is also supported, via an 
instruction abort mechanism. 
The utility of the larger spaces is 
enhanced by the optional separa- 
tion of program and data and the 
implementation of System and 
User modes. System program, 
system data, user program, and 
user data can now each occupy 
64K physical spaces without 
operating system intervention. 
Much larger spaces can be made 
available by reloading the on-Chip 
control registers. 


·UNIX is a trademark of Bell Laboratories. 


September 1983 


Performance. To fully benefit from 
longer programs operating on 
larger blo,cks of data, increas~d 
performance is essential. This is 
provided by the l800 in several 
ways. First, a range of clock 
speeds will be available starting 
with 10 MHz. To achieve full 
benefit from the higher CPU 
speeds without making inordinate 
demands on memory access, on- 
chip cache memory featuring 
automatic update has been imple- 
mented. 
Furthermore, a 16-bit bus option 


doubles the bandwidth to memory. 
For CPU-intensive applications, the 
system can be further tailored for 
cost-effective use of memory with 
the programmable bus-clock scaler 
and the four programmable wait- 
state generators. These devices 
operate directly off the on-Chip 
clock oscillator, which runs at half 
the frequency of the crystal. Addi- 
tional performance enhancement 
results from new addressing 
modes and new instructions. For 
example, hardware multiply and 
divide are standard in both Signed 
and unsigned modes for both 8 and 
16 bits. 


Savings. System cost has been 
reduced through the integration of 
peripheral functions on-chip. Both 
board space and development time 


are saved by the use of the four 
DMAs, four counter/timers, and 
one UART available on the l800 
chip, These features-along with 
the refresh generator, memory 
manager, cache memory, and 
clock oscillator with the CPU- 
result in a virtual mainframe on- 
chip. 


Support. MPU features can be 
converted to system benefits only 
with appropriate development 
suport tools. lilog support starts 
with the UN IX* envi ronment on the 
DEC-VAX or the lilog System 
8000. Cross-software is provided 
that includes an assembler, 
instruction-level simulator, C com- 
piler, linker, loader, and library. 
This software is compatible with 
DEC-VMS and CP/M. 


The l-SCAN 800 is provided for 
debugging hardware and software. 
It features real-time emulation with 
menu-driven, screen-oriented soft- 
ware, Early system prototyping can 
be done with the single-board com- 
puter/development module 
(SBCIDM). This multibus board has 
128K bytes of random access 
memory, four sockets for read-only 
memory, three serial ports, one 
parallel port, and an interface to 
floppy disks. Software for the 
SBC/DM will include CP/M and all 
the cross-software packages. 
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Zilog 


FEATURES 


II 
Enhanced Z80® instruction set that maintains 
object-code compatibility with Z80 microprocessor_ 


Ell 
On-chip paged Memory Management Unit (MMU)_ 


II Large memory address space: 512K byte and 16M 
byte versions. 


IllI 
On-chip, high-speed local or cache memory. 


GENERAL DESCRIPTION 


Zilog's newZ800 family of 8- ano 16-bit microprocessors 
features high-performance microprocessors designed to 
give the end-user a powerful and cost effective solution 
to application requirements. The family consists of the 
8-bit Z80-Bus microprocessors that are packaged in 40- 
and 64-pin dual i'n-line packages, and 16-bit Z-BUS 
microprocessors in 40- and 64-pin packages. The Z800 
family incorporates advanced ,architectural features that 
allow fast and efficient throughput and increased 
memory addressing while maintaining Z80 object code 
compatibility. Z800 microprocessors offer both a C2ontin- 
uing growth path for present Z80-based designs and a 
high-performance microprocessor for future designs. 


Central to the Z800 microprocessors is an enhanced ver- 
sion of the Z80 Central Processing Unit (CPU). To assure 
system integrity, the Z800 microprocessors can operate 
in either user or system mode, allowing protection of 
system resources from user tasks and programs. 
System mode operation is supported by the addition of 
the system Stack Pointer to the working register set. The 
IX and IY registers have been modified so that in addition 
to their regular function as index registers, each register 
can be accessed as a 16-bit general purpose register or 
as two single-byte registers. 


The Z80 CPU instruction set has been retained, meaning 
that the Z800 microprocessors are completely binary- 
code compatible with present Z80 code. The basic ad- 
dressing modes of the Z80 microprocessor have been 


Z800™ IIPU 
ramAly 


Preliminary 
Product 
Specification 


September 1983 


II High performance 16-bit Z-BUS interface or 8-bit 


Z80-compatible bus interface. 


m Four on-chip 16-bit counter/timers. 


[J 
Four on-chip DMA channels. 


m On-chip full duplex UART. 
a ,10-25 MHz CPU processor clock. 


augmented with the addition of Indexed mode with full 
16-bit displacement, Program Counter Relative with 
16-bit displacement, Stack Pointer Relative with 16-bit 
displacement, and Base Index mode. The new address- 
ing modes are incorporated into many of the old Z80 
CPU instructions, resulting in greater flexibility and 
power. Some additions to the instruction set include 
8-and 16-bit signed and unsigned multiply and divide, 
8-and 16-bit sign extension, and a test and set instruction 
to support multiprocessing. The 16-bit instructions have 
been expanded to include 16-bit compare, memory in- 
crement, memory decrement, negate, add, and subtract, 


, in addition to the previously mentioned multiply and 
divide. 


A requirement of many of today's microprocessor-based 
system designs is to increase the memory address 
space beyond the 64K byte range of typical 8-bit 
microprocessors. The Z800 microprocessors have an 
on-chip Memory Management Unit (MMU) that enables 
the microprocessors to address either 512K bytes or 
16M bytes, depending on the device package. In addition 
to enabling the address space to be expanded, the MMU 
performs 
other 
memory 
management 
functions 
previously handled by dedicated off-chip memory 
management devices. 


I/O address space has been expanded by the addition of 
an I/O Page register used to select pages of I/O ad- 
dresses. The 8-bit I/O Page register can select one of 
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256 possible pages of I/O addresses to be active at one 
time, allowing a. total of 64K I/O addresses to be ac- 
cessed. 


There are 256 bytes of on-chip memory present on all 
members of the Z800 family. This memory can be con- 
figured as a high-speed cache or as a fixed address local 
memory. When configured as a cache, the memory can 
be programmed to be instruction onlY,data only, or both 
data and instruction. The cache memory allows pro- 
grams to run significantly faster by reducing the number 
of external bus accesses. Operation and update of the 
cache is performed automatically and is completely 
transparent to the user. When used as a local memory, 
the addresses are programmable, allowing "RAMless" 
systems to be used. 


Many features' that have traditionally been handled by 
external peripheral devices have been incorporated in 
the deSign of the Z800 microprocessors. The "on-chip 
peripherals" reduce system chip count and reduce inter- 
connection on the external bus. All members of the Z800 
family contain an·on-chip clock oscillator. Also present is 
a refresh controller that provides 10-bit refresh ad- 
dresses for dynamic memories. 


The 64-pin versions of the Z800 MPU contain additional 
on-chip peripherals to provide system deSign flexibility. 
To support high·bandwidth data transmission 
four 
Direct Memory Access (DMA) channels are incorp~rated 
on-Chip. Each DMA channel operates using full 24-bit 
source and destination addresses with a 16-bit count. 
The channels can be. programmed to operate in single 
transaction, burst, or continuous mode. System event 
counting and timing. requirements are met with the help 
of the four 16-bit counter/timers. The counter/timer func- 


~ions can be externally controlled with gate and trigger 
Inputs, and can be programmed as retriggerable or 
nonretriggerable. Also, a full duplex UART, capable of 
handling a variety of data and character formats, is pre- 
sent to facilitate asynchronous serial communication. 


zaoo CPU 


User and System Modes of Operation 


The Z800 CPU can operate in either user or system 
mode. In user mode, some instructions cannot be ex- 
ecuted and some registers of the CPU are inaccessible. 
In general, this mode of operation is intended for use by 
application programs. In system mode, all of the instruc- 
tions can be executed and all of the CPU registers can 
be accessed. This mode is intended for use with pro- 
grams that perform operating system functions. This 
separation of CPU resources promotes the integrity of 
the system, since programs op~rating in user mode can- 
not access those aspects of the CPU that deal with 
system interface events. 
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Regardless of whether the 8- or 16-bit bus is used, all 
members of the Z800 family feature programmable bus 
timing, allowing the user to tailor timing to the individual 
system. Upon reset the Z800 microprocessors can be 
programmed to have system timing that is one-fourth, 
one-half, or equal to the speed of the CPU, with one-half 
being the default. In addition to clock scaling, program- 
mable wait states can be inserted during various bus 
transactions. Without the use of external· hardware, one 
to th~ee wait states can be inserted into memory, I/O, 
and Interrupt acknowledge transactions. Furthermore, 
separate memory wait states can be specified for upper 
and lower memory areas, facilitating the use of different 
speeds of ROMs and RAMs in the same system. 


An additional featu re of the 16-bit bus interface is the 
ability to support "nibble-mode" dynamic RAMs. Using 
this feature (known as burst mode), the bus bandwidth of 
memory read transactions is essentially doubled. Burst 
mode transactions have the further benefit of allowing 
the cache to operate more efficiently by guaranteeing a 
high probability that the contents of the accessed 
memory will be present in the cache. 


The Z800 family supports Zilog's ExtendedProcessor Ar- 
chitecture (EPA) in a number of ways. All members are 
capable of trapping Extended Processor Unit (EPU) in- 
structions in order to perform software emulation of the 
EPU. The Z8216 directly interfaces with an EPU such as 
the Z8070 Floating Point Unit and operates in a manner 
that is completely transparent to the user and the pro- 
gram. The other members of the Z800 family can inter- 
face easily with EPUs with the aid of support software. 


The pin functions of four versions of the Z800 MPU, 
Z8108, Z8208, Z8116, and Z8216, are shown in Figures 
1-4, respectively. A block diagram of the Z800 M PU is 
shown in Figure 5. 


To further support the dual user/system mode, there are 
two copies of the Stack Pointer-one for the user stack 
and another for the system stack. These two stacks 
facilitate the task switching involved when interrupts or 
traps occur. To ensure that the user stack is free of 
system information, the information saved on the occur- 
rence of interrupts or traps is always pushed onto the 
sy.stem stack before the new program status is loaded. 
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Figure 5. zaoo MPU Block Diagram 


Address Spaces 


The Z8aa CPU architecture supports four distinct ad- 
dress spaces corresponding to the different types of 
locations that can be accessed by the CPU. These four 
address spaces are: 


III 
CPU register space 


II CPU control and status register space 


• 
Memory address space 


• 
I/O address space 


CPU Register Space. The CPU register space consists 
of all of the registers in the CPU register file. The CPU 
registers are used for data and address manipulation .. 
Access to these registers is specified in the instruction. 
The CPU registers are labeled F, A, B, C, D, E, H, L, F', 
A', B', C', D/, E', H', L', IX, IY, SSP, USP, PC, I, and R. 
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CPU Control and Status Register Space. The CPU 
control register space consists of all of the control and 
status registers found in the CPU control register file. 
These registers govern the operation of the CPU and are 
accessible only by the privileged Load Control instruc- 
tion. The registers in the CPU control file consist of the 
Master Status register, Bus Timing and Initialization 
register, Bus Timing and Control register, InterruptlTrap 
Vector Table Pointer, I/O Page register, System Stack 
Limit register, Trap Control register, Interrupt Status 
register, Cache Control register, and Local Address 
register. 


Memory Address Space. Two memory address spaces 
are supported by the Z8aa CPU; onefor user and one for 
system mode of operation. They are selected by the 
User/System Mode (U/S) bit in the Master Status 
register, which governs the selection of page descriptor 
registers during address translation. 
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Each address space can be viewed as a string of 64K 
bytes numbered consecutively in ascending order. The 
8-bit byte is the basic addressable element in the 
memory address spaces. However, there are other ad- 
dressable data elements: bits, 2-byte words, byte strings 
and multiple-byte EPU operands. 


The address of a multiple-byte entity is the address of the 
byte with the lowest address. Multiple-byte entities can 
be stored beginning at either even or odd memory ad- 
dresses. 


I/O Address Space. I/O addresses are generated only 
by the I/O instructions IN, OUT, and the I/O block move 
instructions. Logical I/O addresses are eight bits in 
le.ngth, augmented by the A register on lines Aa-A15 in 
Direct Address addressing mode and by the B register 
on lines Aa-A15 in Indirect Register addressing mode 
Clnd for block I/O instructions. The 16-L .. t logical I/O ad- 
dress is always extended by appending the contents of 
the 8-bit page register to the augmented I/O address. 
Thus the complete address generated to address an 1/0 
port consists of an I/O page number on A23-A16, the con- 
tents of the A or B register on Aa-A15, and the 8-bit I/O 
address on A7-AQ. 


Unlike memory references, in which a 16-bit word store 
or fetch can generate two memory references, an 1/0 
word store or fetch is always one 1/0 bus transaction 
regardless of bus size or I/O port address. Note: 
however, that on-chip peripherals with word registers 
are accessed via word I/O instructions for those 16-bit 
registers, regardless of the external bus size. 
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Data Types 


The CPU can operate on bits, binary-coded decimal 
(BCD) digits (4 bits), bytes (8 bits), words (16 bits), byte 
strings, and word strings. Bits in registers or memory 
can be set, cleared, and tested. BCD digits, packed two 
to the byte, can be manipulated with the Decimal Adjust 
Accumulator instruction in conjunction with binary addi- 
tion and subtraction. Bytes" are operated on by 8-bit load, 
arithmetic, logical, and shift and rotate instructions. 
Words are operated on in a similar manner by the 16-bit 
load and 16-bit arithmetic instructions. Block move and 
search operations can manipulate byte strings up to 64K 
bytes long. Block I/O word instructions can manipulate 
word strings up to 32K words long. To support EPU 
operations, byte strings up to 16 bytes in length can be 
transferred by the CPU. 


CPU Registers 


The Z8aa MPU contains 23 programmable registers in 
the CPU register address space. These registers are 
illustrated in Figure 6. 


Primary and Working Register Set. The working 
register set is divided into the two 8-bit register 
files-the primary fil€ and alternate (designated by , 
[prime]) file. Each file contains an 8-bit accumulator (A), 
a Flag register (F), and six general-purpose registers (B, 
C, 0, E, "H, and L). Only one file can be active at any 
given time. Upon reset, the primary register file is active. 
Exchange instructions allow the programmer to ex- 
change the active file with the inactive file. 
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Figure 6. CPU Register Configuration 
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The accumulator is the destination register for 8-bit 
arithmetic and logical operations. The six general- 
purpose registers can be paired (BC, DE, and HL) to form 
three 16-bit general-purpose registers. The HL register 
pair serves as a 16-bit accumulator for 16-bit arithmetic 
operations. 


CPU Flag Register. The Flag register contains six flags 
that are set or reset by various CPU operations. This 
register is illustrated in Figure 7. 
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Figure 7. CPU Flag Register 


The flags in this register are: 


Carry (C). This flag is set when an add instruction 
generates a carry or a subtract instruction generates a 
borrow. Certain logical and rotate and shift instructions 
affect the Carry,flag. 


Add/Subtract (N). This flag is used by the Decimal Adjust 
Accumulator instruction to distinguish between add and 
subtract operations. The flag is set for subtract opera- 
tions and cleared for addition operations. 


Parity/Overflow (PIV). This flag is set or cleared depend- 
ing on the operation being performed. During arithmetic 
operations it is set to indicate a twos complement 
overflow. During logical and rotate operations, this flag 
is set to indicate even parity of the result, or cleared to 
indicate odd parity. 


Half Carry (H). This flag is set if an 8-bit arithmetic opera- 
tion generates a carry or borrow between bits 3 and 4, or 
if a 16-bit operation generates a carry or borrow between 
bits 11 and 12. This bit is used to correct the result of a 
packed BCD addition or subtract operation. 


Zero (Z). This flag is set if the result of an arithmetic or 
logical operation is a zero. 


Sign (S). This flag stores the state of the most significant 
bit of the accumulator. The Sign flag is also used to in- 
dicate the res'ults of a test and set instruction. 


Dedicated CPU Registers 


Index Registers. The two Index registers, IX and IY, 
each hold a 16-bit base address that is used in the Index 
addressing mode. The Index registers can also function 
as general-purpose registers with the upper and lower 
bytes capable of being accessed individually. The high 
and low bytes of the IX register are called IXH and IXL. 
The high and low bytes of the IY register are called IYH 
and IYL. 


Interrupt Register. The Interrupt register (I) is used in in- 
terrupt mode 2 to 'generate a 16-blt indirect logical ad- 
dress to an interrupt service routine. The Interrupt 
register supplies the upper eight bits of the indirect ad- 
dress and the interrupting peripheral supplies the lower 
eight bits. 
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Program Counter. The Program Counter (PC) is used to 
sequence through instructions in the currently-executing 
program and to generate relative addresses. The Pro- 
gram Counter contains the 16-bit logical address of the 
currerit instruction being fetched from memory. 


R Register. The R register can be used as a general- 
purpose 8-bit read/write register. The R register is not 
associated with the refresh address and its contents are 
changed only by the user.' 


Stack Pointers. Two hardware Stack Pointers, the user 
Stack Pointer (USP) and the system Stack Pointer (SSP), 
support 
the 
dual 
mode 
of 
operation 
of 
the 
microprocessor. The SSP is used for saving information 
when an interrupt or trap occurs, and for supporting 
subroutine calls and returns in system mode. The USP is 
used for supporting subroutine calls and returns in user 
mode. 
' 


Status and Control Registers. There are ten status and 
control registers available to the programmer in the 
Z800 MPU. Table 1 shows the addresses occupied by 
the registers in the status and control register address- 
ing space. 


Table 1. Status and Control Register Addressing Space 


Address 
Control Register Name 
(Hexadecimal) 


Bus Timing and Control 
Control 02 


Bus Timing and Initialization 
Control FF 
Cache, ControP' 
Control 12 


Interrupt Status 
Contro! 16 
InterruptfTrap Vector Table 
Control 06 
1/0 Page Register 
Control 08 


Local Address Register2 
Control 14 
Master Status (MSR) 
Control 00 


Stack Limit 
Control 04 


Trap Control 
Control 10 


NOTES: 
1. See section on on-chip memory for register description. 
2. See section on multiprocessing mode of operation for register description. 


Bus Timing and Control Register. This 8-bit register 
(Figure 8) governs the timing of transactions to high 
memory addresses and the daisy-chain timing for inter- 
rupt requests, as well as the functionality of requests on 
the various Z800 MPU interrupt request lines. On reset, 
this register is cleared to aliOs. 
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Figure 8. Bus Timing and Control Register 
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The fields in this register are: 


I/O Wait Insertion (I/O). This 2-bit field specifies the 
number of additional wait states (in addition to the one 
automatically inserted for I/O) to be inserted by the CPU 
in both I/O transactions and vector response timing (00 
= none, 01 = one, 10 = two, 11 = three). 


High Memory Wait Insertion (HM). This 2-bit field 
specifies the number of automatic wait states (00 = 
none, 01 = one, 10 = two, 11 = three) for the CPU to 
insert in memory transactions when the MMU is enabled 
and there is a 1 in bit 15 of the selected page descriptor 
register. 


Daisy Chain Timing (DC). This 2-bit field determines the 
number of additional automatic wait states the CPU in- 
serts while the interrupt acknowledge daisy chain is set- 
tling (00 = none, 01 = one, 10 = two, 11 = three). A 
value of 01 in the DC field indicates that one additional 
cycle will be added to the four cycles that normally 
elapse between interrupt acknowledge, AS and OS 
assertions. 


Bus Timing· and Initialization Register. This 8-bit 
register (Figure 9) is used to specify the duration of con- 
trol signals for the external bus when the MMU is dis- 
abled or when the MMU is enabled and there is a a in bit 
15 of the selected page descriptor register. It also con- 
trols the relationship between internal processor clock 
rates and bus timing. It can be programmed by external 
hardware upon reset. 


During reset this register is initialized to one of two set- 
tings, depending on the state of the Wait input line on the 
rising edge of reset: if the Wait line is not asserted, the 
register is set to OOH. If the Wait line is asser.ted during 
reset, then this register is set to the contents of the AD 
lines. 


Figure 9. Bus Timing and Initialization Register 


The fields in this register are: 


Clock Scaling (CS). This 2-bit field specifies the scaling of 
the CPU clock for all bus transactions (00 = one bus 
clock cycle is equal to two internal processor clock 
cycles, 01 = bus clock cycle is equal to the internal 
processor clock cycle, 10 = one bus clock cycle is 
equal to four internal processor clock cycles, 11 = 
reserved). This field cannot be modified by software. 


Low Memory Wait Insertion (LM). This 2-bit field 
specifies the number of automatic wait states (00 = 
none, 01 = one, 10 = two, 11 = three) for the CPU to 
insert in memory transactions when the MMU is disabled 
or when the MMU is enabled and there is a a in bit 15 of 
the selected page descriptor register. 
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Multiprocessor Configuration Enable (MP). This ·1-bit field 
enables the multiprocessor mode of operation (0 = 
disabled, 1 = enabled). (See the multiprocessor mode 
section). 


Bootstrap Mode Enable (BS). This 1-bit field enables the 
bootstrap mode of operation (0 = disabled,1 = en- 
abled). (See the UART section for details about bootstrap 
mode.) 


Interrupt Status Register. This 16-bit register (Figure 
10) indicates which interrupt mode is in effect and which 
interrupt sources have interrupt requests pending. It also 
contains the bits that specify whether the interrupt in- 
puts are to be vectored. Only the interrupt vector enable 
bits are writeable; all other bits are read-only. 


Figure 10. Interrupt Status Register 


The fields in this register are: 


Interrupt Request Pending (lP). When bit IPn is set to 1, 
an interrupt request from sources at level n is pending. 
(See the Interrupt and Trap Structure section.) 


Interrupt Mode (1M). A value of n in .this 2-bit. field in- 
dicates that interrupt mode n is in effect. This field can 
be changed by executing the 1M instruction. 


Interrupt Vector Enable (I). These four bits indicate 
whether each of the four interrupt inputs are to be vec- 
tored. When In is set to 1, interrupts on the Interrupt n 
line are vectored when the CPU is in interrupt mode 3; 
when cleared to 0, all interrupts on this line use the same 
entry in the InterruptlTrap Vector Table. These bits are 
ignored except in interrupt mode 3. 


Interrupt/Trap Vector Table Pointer. This 16-bit 
register (Figure 11) contains the most Significant 12 bits 
of the physical address at the beginning of the Inter- 
ruptlTrap Vector Table; the lower 12 bits of the phYSical 
address are assumed to be O. The four least significant 
bits of this register must be O. 


Figure 11. Interrupt/Trap Vector Table Pointer 


110 Page Register. This 8-bit register (Figu re 12) in- 
dicates the bits to be appended to the 16 bits that are 
output during I/O transactions during the I/O address 
phase. 
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Figure 12. 1/0 Page Register 
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Master Status Register. The Master Status register 
(Figure 13) is a 16-bit register containing status informa- 
tion about the currently-executing program. This register 
is cleared to 0 during reset. 
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Figure 13. Master Status Register 


The fields in this register are: 


Interrupt Request Enable (En). There are seven Interrupt 
Enable bits, one for each type of maskable interrupt 
source (both external and internal). When bit En is set to 
1, interrupt requests from sources at level n are ac- 
cepted by the CPU; when this bit iscleared to 0, interrupt 
requests at level n are not accepted. 


Single-Step (SS). While this bit is set to 1, the CPU is in 
single-stepping mode; while this bit is cleared to 0, 
automatic single-stepping 
i.s disabled. This bit is 


automatically cleared when a trap or interrupt is taken. 


Single-Step Pending (SSP). While this bit is set to 1, the 
CPU generates a trap prior to executing an instruction. 
The SS bit is a'utomatically copied into this field at the 
completion of each instruction. This bit is. automatically 
cleared to 0 when a Single-Step, Page Fault, Privileged 
Instruction, Break-on-Halt or Division trap is taken so 
that the SSP bit in the saved Master Status register is 
cleared to O. 


Breakpoint-on-Halt Enable (BH). While this bit is set to 1, 
the CPU generates a Breakpoint trap whenever a halt in- 
struction is encountered; while this bit is cleared to 0, the 
halt instruction is executed normally. 


User/System Mode (U/S). While this bit is cleared to 0, 
the CPU is in the system mode of operation; while it is 
set to 1 the CPU is in the user mode of operation. 


System Stack Limit Register. This 16-bit register 
(Figure 14) indicates when a System Stack Overflow 
Warning trap is to be generated. If enabled by setting a 
control bit in the Trap Status register, pushes onto the 
system stack cause the 12 most significant bits in this 
register to be compared to the upper 12 bits of the 
system Stack Pointer and a trap is generated if they 
match. The low-order four bits of this register must be O. 
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Figure 14. System Stack Limit Register 
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Trap Control Register. This 8-bit register (Figure 15) 
enables the maskable traps. 
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Figure 15. Trap Control Register 


The bits in this register are:- 


System Stack Overflow Warning (S). While this bit is set 
to 1 the CPU generates a Stack Overflow Warning trap 
when the system stack enters the specified region of 
memory. Upon reset this register is, initialized to all Os. 


EPU Enable (E). While this bit is cleared to 0, the CPU 
generates a trap whenever an EPA instruction. is en- 
countered. 


Inhibit User I/O (/). While this bit is set to 1, the CPU 
generates a Privileged Instruction trap when an 1/0 in- 
struction is encountered in user mode. 


Cache Control and Local Address Registers. See the 
. on-chip memory section for information about the Cache 
Control register, and the multiprocessor mode section 
for information about the Local Address register. 


Interrupt and Trap Structure 


The l800 MPU provides a very flexible and powerful in- 
terrupt and trap structure. Interrupts are external asyn- 
chronous events requiring CPU attention, and are 
generally triggered by peripherals needing service. 
Traps are synchronous events resulting from the execu- 
tion of certain instructions. 


Interrupts. Two types of interrupt, nonmaskable and 
maskable, are supported by the l800 MPU. The non- 
maskable interrupt (NMI) cannot be disabled (masked) 
by software and is generally reserved for highest priority 
external events that require immediate attention. 
Maskable interrupts, however, can be selectively dis- 
abled by software. Both nonmaskable and maskable in- 
terrupts can be programmed to be vectored or nonvec- - 
tored. The CPU accepts interrupts between instructions 
with the exception of the block move, search, and I/O in- 
structions, which can be safely interrupted after any 
iteration and restarted after the interrupt is serviced. 


Interrupt Sources. The l800 MPU accepts non- 
maskable interrupts on the NMI pin only. The l800 MPU 
accepts maskable interrupts on the INT pins, and from 
the on-chip counter/timers, DMA channels, and the 
UART receiver and transmitter. The 40-pin members of 
the l800 family accept maskable interrupts on INTA 
only. 


2259'()13, 014, 015 


Interrupt Lines A, B, and C can be selectively program- 
med to support. vectored interrupts by setting the ap- 
propriate bits in the Interrupt Status register. The exter- 
nal interrupts can be programmed to be vectored or 
nonvectored in interrupt mode 3. 


Interrupt Modes of Operation. The CPU has fou r 
modes of interrupt handling. The first three modes ex- 
tend the l80 interrupt modes to accommodate addi- 
tional interrupt input lines in a compatible fashion. The 
fourth mode provides more flexibility in handling the in- 
terrupts. On-chip peripherals use the fourth mode 
regardless of which mode is selected for externally 
generated interrupt requests. The interrupt mode is 
selected by using the privileged instructions 1M 0, 1M 1, 
1M 2, or 1M 3. On reset, the l800 MPU is automatically 
set to interrupt mode O. The current interrupt mode in ef- 
fect can be read from the Interrupt Status register. 


Mode O. This mode is identical to the 8080 interrupt 
response mode. With this mode, the interrupting device 
on any of the maskable interrupt lines can place a call or 
restart instruction on the data bus and the CPU will ex- 
ecute it. As a result, the interrupting device, instead of 
the memory, provides the next instruction to be ex- 
ecuted. 


Mode 1. When this mode is selected, the CPU responds 
to a maskable external interrupt by executing a restart to 
the logical address 0038H in the system program ad- 
dress space. 


Mode 2. This mode is a vectored interrupt response 
mode. With a single 8-bit byte from the interrupting 
device, an indirect call can be made to any memory 
location. With this mode the system maintains a table of 
16-bit starting addresses for every interrupt service 
routine. This table can be located anywhere in the 
system mode logical data address space on a 256-byte 
boundary. When an interrupt is accepted, a 16-bit pointer 
is formed to obtain the desired interrupt service routine 
starting address from the table. The upper eight bits of 
this pOinter are formed from the contents of the I 
register. The lower eight bits of the pointer must be sup- 
plied by the interrupting device. The 16-bit pOinter so 
formed is treated as a logical address in the system data 
address space, which can be translated by the MMU to a 
physical address. 


Mode 3. This is the intended mode of operation for 
systems that take advantage of the enhancements of the 
l800 microprocessor family (such as single-step and 
user/system mode) since the Master Status register is 
automatically saved and another loaded for the inter- 
rupts. Also, vector tables can be used for the external in- 
terrupt sources to provide more interrupt vectors for the 
l8000™ family, l80 family, and l8500 Universal 
Peripherals. 


When an interrupt _ request (either maskable or non- 
mqskable) is accepted, the Master Status register, the 
address of the next instruction to be executed, and a 
16·bit •• reason code" are pushed onto the system stack. 
A new Master Status register and Program Counter are 


then fetched from the InterruptlTrap Vector Table. The 
"reason code" for externally generated interrupts is the 
contents of the bus during the interrupt acknowledge se- 
quence; for 8-bit data buses, the most significant byte of 
the reason code is zero. For interrupts generated by on- 
chip peripherals, the reason code identifies which 
peripheral generated the interrupt and is identical to the 
vector address in the Interrupt/Trap Vector Table. The In- 
terrupt/Trap Vector Table Pointer is used to reference 
the table. 


Traps. The l800 CPU supports eight traps that are 
generated internally. The following traps can be dis- 
abled: the EPA trap, which allows software to emulate an 
EPU; the Stack Warning trap, which is taken at the end of 
an instruction causing the trap; the Breakpoint-on-Halt 
trap, which is taken when a halt instruction is en- 
countered; and the Single-Step trap, which is taken for 
each instruction. In addition, I/O instructions can be 
specified as privileged instructions. Traps cause the in~ 
struction to be terminated without altering CPU registers 
(except for the system Stack Pointer, which is modified 
when the program status is pushed onto the system 
stack). 


The saving of the program status on the system stack 
and the fetching of a- new program status from the Inter- 
rupt/Trap Vector Table is the same in any interrupt mode 
of operation; 


Traps can only occur if the trap generating features of 
the l800 CPU (such as System Stack Overflow warning) 
have been explicitly enabled. Traps cannot occur on in~ 
structions of the l80 instruction set unless explicitly 
enabled by the operating system using l800 CPU exten- 
sions. 


Extended Instruction. This trap occurs when the CPU en- 
counters an extended instruction while the Extended 
Processing Architecture (EPA) bit in the Trap Control 
register is O. Four trap vectors are used by the EPA 
trap-one for each type of EPA instruction. This greatly 
simplifies trap handlers that use I/O instructions to ac- 
cess an EPU or software to emulate an EPU. 


Privileged Instructfon. This trap occurs whenever an at- 
tempt is made to execute a privileged instruction while 
the CPU is in user mode (User/System Mode control bit 
in the Master Status register is 1). 


System Call. This trap occurs whenever a System Call 
(SC) instruction is executed. 


Access Violation. This trap occurs whenever the MMU's 
translation mode is enabled and an address to be 
translated is invalid or (for writes) is write-protected. 


System Stack Overflow Warning. This trap occurs only 
while the Stack Overflow Warning bit in the Trap Control 
register is set to 1. For each system stack push opera- 
tion, the most significant bits in the Stack Pointer 
register are compared with the contents of the Stack 
Limit register and a trap is signaled if they match. The 
Stack Overflow Warning bit is then automatically cleared 
in order to prevent repeated traps. 
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Division Exception. This trap occurs whenever the 
divisor is zero (divide-by-zero case) or the true quotient 
cannot be represented in the destination precision 
(overflow); the CPU flags are set to distinguish these two 
cases. 


Single-Step. This trap occurs before executing an in- 
struction if the Single-Step Pending control bit in the' 
Master Status register is set to 1. Two control bits in the 
Master Status register are used for the Single-Step trap. 
The Single-Step bit (bit 8), on being set when previously 
clear, causes a trap to occur after the execution of the 
next instruction. While this bit is set to 1, if an instruction 
execution causes a trap, the Single-Step trap occurs 
after the execution of the trap-handling routine. The 
Single-Step Pending bit (bit 9), is used by the processor 
to ensure that only one Single-Step trap occurs for each 
instruction executed while the Single-Step bit is set to 1. 


Breakpoint-on-Halt. This trap occurs whenever the 
Breakpoint-on-Halt control bit in the Master Status 
register is·1 and a halt instruction' is encountered. 


Interrupt and Trap Disabling. Maskable interrupts can 
be enabled or disabled independently via software by 
setting or clearing the appropriate control bits in the 
Master Status register. 


A 7-bit mask field in the Master Status register indicates 
which of the requested interrupts will be accepted. Inter- 
rupt requests are grouped as follows, with each group 
controlled by a separate Interrupt Enable control bit. The 
list is presented in order of decreasing priority, with 
sources within a group listed in order of descending 
priority. 


• 
Maskable Interrupt A line (bit 0) 


• 
Counter/Timer 0, DMAO (bit 1) 


• 
Maskable Interrupt B line (bit 2) 


• 
Counter/Timer 1, UART receiver, DMA 1 (bit 3) 


• 
Maskable Interrupt C line (bit 4) 


• 
Counter/Timer 2, UART transmitter, DMA2 (bit 5) 


• 
Counter/Timer 3, DMA3 (bit 6) 


When a source of interrupts has been disabled, the CPU 
ignores any interrupt request from that source. 


The System Stack Overflow Warning trap, I/O instruc- 
tions in user mode trap (Privileged Instruction trap), or 
Extended Instruction trap can be enabled by setting con- 
trol bits in the Trap Control register, and the Single-Step 
and Breakpoint-on-Halt trap can be enabled by setting 
control bits in the Master Status register; these are the 
only traps that can be disabled. 


Interrupt/Trap Vector Table. The, format of the Inter- 
rupt/Trap Vector Table consists of pairs of Master Status 
register and Program Counter words, one pair for each 
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separate on-Chip interrupt or trap source. For each ex- 
ternal interrupt, there is a separate Master Status 
register word and Program Counter word (for use if the 
input is not vectored). If the external interrupt is vec- 
tored, a vector table consisting of one Program Counter 
word for each of the 128 possible vectors that can be 
returned for each input line is used instead of the 
dedicated Program Counter word; thus for vectored in- 
terrupts, there is only one Master Status register for 
each interrupt type. 


The format of the Interrupt/Trap Vector Table is shown in 
Table 2. 


Table 2. InterruptiTrap Vector Table 


Address 
(Hexadecimal) 


00 


04 
08 


OC 
10 


14 
18 
1C 
20 
24 


28 
2C 
30 
34 


38 
3C 
40 
44 
48 
4C 
50 
54 
58 
5C 
60 
64 
68-6C 


70-16E 


170-26E 


270-36E 


Unused 


NMI Vector 


Contents 


Interrupt Line A Vector (End of Process) 


Interrupt Line B Vector 


Interrupt Line C Vector 


C-TO 


C-T1 


C-T2 


C-T3 


DMAO Vector 


DMA1 Vector 


DMA2 Vector 
DMA3 Vector 
UART Receiver Vector 
UART Transmitter Vector 
Single-Step Trap Vector 
Breakpoint-on-Halt Trap Vector 
Division Exception Trap Vector 
Stack Overflow Warning Trap Vector 


Page Fault Trap Vector 


System Call Trap Vector 
Privileged Instruction Trap Vector 


EPU .... Memory Trap Vector 
Memory .... EPU Trap Vector 


A .... EPU Trap Vector 


EPU Internal Operation Trap Vector 


Reserved 
128 Program Counters for NMI and In- 
terrupt line A Vectors (MSR from 04 and 
08, respectively) 
128 Program Counters for Interrupt Line 
B Vectors (MSR from OC) 
128 Program Counters for Interrupt Line 
C Vectors (MSR from 10) 


Addressing Modes 


Addressing modes (Figure 16) are used by the CPU to 
calculate the effective address of an operand needed for 
execution of an instruction. Nine addressing modes are 
supported by the Z800 CPU. Of these nine, four are addi- 
tions to the Z80 addressing modes (Indexed with 16-bit 
displacement, Stack Pointer Relative, Program Counter 
Relative, and Base Index) and the remaining five modes 
are either existing or extensions to the existing Z80 ad- 
dressing modes. 


Register. The operand is one of the 8-bit registers (A, B, 
C, D, E, H, L, IXH, IHL, IYH or IYL); or one of the 16-bit 
registers (BC, DE, HL, IX, IY, or SP), or one of the special 
byte registers (I or R). 


Immediate. The operand is in the instruction itself and 
has no effective address. 


Register Indirect. The contents of a register specify the 
effective address of an operand. The HL register is the 
register most often used for memory accesses. The C 
register is used for I/O and control register space ac- 
cesses. 


Direct Address. The effective address of the operand is 
the location whose address is contained in the instruc- 


Instruction Set 


Notation 


Addressing Modes. The following notation is used to 
describe the addressing modes and instruction opera- 
tions as shown in the instruction set. 


BX 
Base Index 


DA 
Direct Address 


1M 
Immediate constant 


IR 
Indirect Register 
X 
Index 


R 
Single register of the set (A, B, C, D, E, H, L) 
RA 
Relative address f 


RX 
A byte in the IX or IY register 


SP 
Current Stack Pointer ' 


SR 
Stack Relative 
SX 
Short Index 
n 
8-bit constant 
nn 
16-bit constant 


Symbols. The following symbols are used to describe 
the instruction set. 


dst 
(Destination location or contents) 
src 
(Source location or contents) 
n 
(An 8-bit constant) 
nn 
(A 16-bit constant) 


SP 
(Current Stack Pointer) 


p 
(Interrupt mode) 
(C) 
(I/O port pOinted to by C register) 


SSP 
(System Stack Pointer) 
USP 
(User Stack POinter) 


Assignment of a value is indicated by the symbol" -". 
For example, 


• Abbreviated set 


tion. Depending on the instruction, the specified operand 
is either in I/O or data memory space. 


Index. The effective address of the operand is the loca- 
tion specified by adding the 16-bit address contained in 
the instruction to a twos complement "index" contained 
in the HL, IX, or IY register. 


Short Index. The effective address of the operand is the 
location computed by adding the 8-bit twos complement 
signed displacement contained in the instruction to the 
contents of the IX or IY register. This addressing mode is 
equivalent to the Z80 CPU indexed mode. 


Relative. An 8- or 16-bit displacement contained in the 
instruction is added to the Program Counter to generate 
the effective address of the operand. 


Stack Pointer Relative. The effective address of the 
operand is the location computed by adding a 16-bit twos 
complement displacement contained in the instruction 
to the contents of the Stack Pointer. 


Base Index. The effective address of the operand is the 
location whose address is computed by adding the con- 
tents of HL, IX, or IY to the contents of another of these 
three registers. 


dst - 
dst + src 


indicates that the source data is added to the destination 
data and the result is stored in the destination location. 
The notation "addr(n)" is used to refer to bit "n" of a 
given location. For example, 


dst(?) 


specifies bit? of the destination. 


Flags. The F register contains the following six flags. 


C 
Carry flag 


H 
Half carry flag 


N 
Add/Subtract flag 
P/v 
Parity/Overflow flag 
S 
Sign flag 
Z 
Zero flag 


Condition Codes. The following symbols describe the 
condition codes. 


Z* 
Zero 


NZ* 
Not zero 


C* 
Carry 
NC* 
No carry 


S 
Sign 
NS 
No sign 


V 
Overflow 
PE 
Parity even 


PO 
Parity odd 


P 
Positive 


M 
Minus 
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Mode 


Register 


Immediate 


Register 
Indirect 


Direct 
Address 


*Index 


Short Index 


*Relative 


*Stack Pointer 
Relative 


*8ase Index 


Operand Addressing 


In the Instruction 
In a Register 
In Memory or I/O 


ESTER ADDRESS J-.I OPERAND 


OPERAND 


1 REGISTER ADDRESS J-.I ADDRESS .------- OPERAND 


..... __ 
A_D_DR_E_S_S_ ..... .-----------... I OPERAND 


REGISTER ADDRESS 
INDEX 


..... _B_A_SE_AD_D_R_E_SS_.r--------I~·0__1 OPERAND 


REGISTER ADDRESS 


DISPLACEMENT 
OPERAND 1 


PCVALUE ~ 
• 
..... ---:...-0--I~O-PE-R-A-N-D., 
DISPLACEMENT 


SPVALUE t------t 
..... ---~I 
OPERAND 
DISPLACEMENT 


REGISTER ADDRESS 1 


REGISTER ADDRESS 2 


-New Z800 Family addreSSing modes 
Figure 16. Addressing Modes 
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Operand Value 


The content of the 
register 


In the instruction 


The content of the location 
whose address is in the 
register 


The content of the location 
whose address is in the 
instruction 


The content of the location 
whose address is the 16·bit 
address in the instruction, 
offset by the content of 
the 16·bit register 


The content of the location 
whose address is in the 16·bit 
register, offset by the 8·bit 
displacement in the 
instruction 


Tile content of the location 
whose address is the 
content of the Program 
Counter, offset by the 
displacement in the 
instruction 


The content of the location 
whose address is the 
content of the Stack 
Pointer, offset by the 
displacement in the 
instruction 


The content of the location 
whose address is the 
content of a register, 
offset by the displacement 
in'a register 


2259·016 


a·Bit Load Group 


Flags 
Instruction 
Addressing Modes 
S 
Z 
H. PN N 
C 
Operation 


EX A,src 
src = R,RX,IR,DA,X,SX, 
0 
0 
0 
0 
0 
0 
Exchange Accumulator 


RA,SR,BX 
A- src 


EX H,L 
0 
0 
• 
• 
• 
• 
Exchange H,L 
H-L 


LD dst,src 
src=A 
0 
0 
0 
0 
0 
0 
Load Accumulator 


dst = R,RX,IR,DA,X, 
dst - 
src 
SX,RA,SR,BX, 
(BC),(DE) 


or 
t-J = 
src = R,RX,IM,IR,DA, 
C) 
C 
X,SX,RA,SR,BX, 
~ 
(BC),(DE) 
I(J 


dst=A 
= 


LD dst,src 
dst= R 
0 
0 
0 
0 
0 
0 
Load Register (Byte) 
src = R,RXt,IM,IR,SX 
dst - 
src 
or 


dst = R,RXt,IR,SX 
src= R 


LD dst,n 
dst = R,RX,IR,DA,X, 
0 
0 
0 
0 
0 
0 
Load Immediate (Byte) 
SX,RA,SR,BX 
dst - 
nn 


* LDUD dst,src 
dst=A 
0 
~ 
0 
~ 
0 
~ 
Load in User Data 
src = IR or SX in user 
Space (Byte) 
space 
dst - 
src 
or ' 


dst = IR or SX in user 
space 


src=A 


* LDUP dst,src 
dst=A 
0 
~ 
0 
~ 
• 
~ 
Load in User Program 
src = IR or SX in user 
Space (Byte) 
space 
dst - 
src 
or 


dst = IR or SX in user 
space 
src=A 


16·Bit Load Group 


Flags 
Instruction 
Addressing Modes 
S 
Z 
H PN N 
C 
Operation 


EX src,HL 
src = DE,IX,IY 
0 
0 
0 
0 
0 
0 
Exchange H L with 
Addressing Register 


src - 
HL 


* Privileged instruction. 
t Accessing bytes of IX or IY precludes use of H or l. 
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16·Bit Load Group (Continued) 


Flags 
Instruction 
Addressing Modes 
S 
Z 
H PN N 
C 
Operation 


EX (SP),dst 
dst = HL,IX,IY 
• 
• 
• 
• 
• 
• 
Exchange Addressing 
Register with Top 
of Stack 


(SP) - 
dst 


EX AF,AF' 
t 
t 
t 
t 
t 
Exchange Accumulatorl 
Flag with 
Alternate Bank 


AF-AF' 


EXX 
• 
• 
• 
• 
• 
• 
Exchange Byte/Word 
Registers with Alternate 
Bank 


BC- BC' 
DE - 
DE' 
HL - 
HL' 


LO[W] dst,src 
dst = HL,IX,IY 
• 
• 
• 
• 
• 
• 
Load Addressing 
src = IM,DA,X,RA,SR,BX 
Register 


or 
dst - 
src 
dst = DA,X,RA,SR,BX 
src = HL,IX,IY 


LO[W] dst,src 
dst = BC,DE,HL,SP 
• 
• 
• 
• 
• 
• 
Load Register Word 
src = IM,IR,DA,SX 
dst - 
src 
or 
dst = IR,DA,SX 
src = BC, DE, H L,SP 


LOW dst,nn 
dst = RR,IR,DA,RA 
• 
• 
• 
• 
• 
• 
Load Immediate Word 


dst - 
nn 


LO[W] dst,nn 
dst= RR 
• 
• 
• 
• 
• 
• 
Load immediate V'v'ord 


dst - 
nn 


LO[W] dst,src 
dst=SP 
• 
• 
• 
• 
0 
• 
Load Stack Pointer 
src = HL,IX,IY,IM,IR, 
dst - 
src 
DA,SX 
or 
dst= IR,DA,SX 
src=SP 


LOAdst,src 
dst= HL,IX,IY 
0 
• 
• 
• 
• 
• 
Load Address 
src = X,RA,SR,BX 
dst - 
address (src) 


POP dst 
dst = RR*,IR,DA,RA 
• 
0 
• 
• 
0 
0 
POP 


dst - 
(SP) 
SP - 
SP + 2 


PUSH src 
src = RR*,IM,IR,DA, 
• 
• 
• 
0 
0 
0 
PUSH 


RA 
SP - 
SP - 
2 
(SP) - 
src 
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Block Transfer and Search Group 


Flags 
Instruction 
Addressing Modes 
S 
Z 
H PN N 
C 
Operation 


CPO 
~ 
~ 
~ 
~ 
• 
Compare and. Decrement 


A - 
(HL) 
HL -'HL - 
1 
Be - 
Be - 
1 


CPDR 
~ 
~ 
~ 
~ 
• 
Compare, Decrement 
and Repeat 


Repeat until Be = 0 or 
match: 
A - 
(HL) 
HL - 
HL - 
1 
1.\1 


Be - 
Be - 
1 
@I) 
8 
CPI 
~ 
~ 
~ 
~ 
• 
Compare and Increment 
iii 
A - 
(HL) 
c:I 


HL - 
HL + 1 
Be - 
Be - 
1 


CPIR 
~ 
~ 
~ 
~ 
• 
Compare, Increment 
and Repeat 


Repeat until Be = 0 or 
match: 
A - 
(HL) 
HL - 
HL + 1 
Be - 
Be - 
1 


LDD 
• 
• 
0 
~ 
0 
• 
Load and Decrement 


(DE) - 
(HL) 
DE - 
DE - 
1 
HL - 
HL - 
1 
Be - 
Be - 
1 


LDDR 
• 
• 
0 
0 
0 
• 
Load, Decrement and 
Repeat 


Repeat until Be = 0: 
(DE),- (HL) 
DE - 
DE - 
1 
HL - 
HL - 
1 
Be - 
Be - 
1 


LDI 
• .' 
0 
~ 
0 
• 
Load and Increment 


(DE) - 
(HL) 
DE - 
DE + 1 
HL - 
HL + 1 
Be - 
Be - 
1 


LDIR 
• 
• 
0 
0 
0 
• 
Load, Increment and 
Repeat 


Repeat until Be = 0: 


(DE) - 
(HL) 
DE - 
DE + 1 
HL - 
HL + 1 
Be - 
Be - 
1 ' 
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a·Bit Arithmetic ~nd Logic Group 


Flags 
Instruction 
Addressing Modes 
S 
Z 
H PN N, 
C 
Operation 


ADC [A,]src 
src = R,RX,IM,IR, 
~ 
~ 
~ 
V 
0 
~ 
Add With Carry (Byte) 
DA,X,SX,RA, 
A-A + src + C 
SR,BX 


ADD [A,]src 
src = R,RX,IM,IR, 
~ 
~ 
~ 
V 
0 
~ 
Add (Byte) 
DA,X,SX,RA, 
A -A + src 
SR,BX 


AND [A,]src 
src = R,RX,IM,IR, 
~ 
~ 
p 
0 
0 
And 
DA,X,SX,RA, 
A -AAND src 
SR,BX 


CP [A,]src 
src = R,RX,IM,IR, 
~ 
~ 
~ 
V 
~ 
Compare (Byte) 
DA,X,SX, RA, 
A- src 
SR,BX 


C?PL [A] 
• 
• 
• 
• 
Complement 
Accumulator 
A- NOTA 


DAA [A] 
~ 
~ 
~ 
p 
• 
~ 
Decimal Adjust 
Accumulator 


A - 
Decimal Adjust A 


DEC dst 
dst = R,RX,IR,DA,X, 
~ 
~ 
~ 
V 
• 
Decrement (Byte) 
SX,RA,SR,BX 
dst - 
dst - 
1 


DIV [HL,]src 
src = R,RX,IM,DA,X, 
~ 
~ 
• 
~ 
• 
• 
Divide (Byte) 
SX,RA,SR,BX 
A - 
HL+src 
L - 
remainder 


DIVU [HL,]src 
src = R,RX,IM,DA,X, 
0 
~ 
• 
~ 
• 
• 
Divide Unsigned (Byte) 
SX,RA,SR,BX 
A~HL+src 
L - 
remainder 


EXTS [A] 
• 
• 
• 
• 
• 
• 
Extend Sign (Byte) 
L-A 
If A(7) = 0, then H - 
00 


else H - 
FF 


INC dst 
dst = R,RX,IR,DA,X, 
~ 
~ 
~ 
V 
0 
• 
Increment (Byte) 
SX,RA,SR,BX 
dst - 
dst + 1 


MULT [A,]src 
src = R,RX,IM,IR,DA, 
~ 
~ 
• 
0 
• 
~ 
Multiply (Byte) 
X,SX,RA,SR,BX 
HL - A x src 


MULTU [A,]src 
src= R,RX,IM,IR,DA, 
0 
~ 
• 
0 
• 
~ 
Multiply Unsigned (Byte) 
X,SX,RA,SR,BX 
HL-A x src 


NEG [A] 
~ 
~ 
~ 
V 
~ 
Negate Accumulator 
A- -A 
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a·Bit Arithmetic and Logic Group (Continued) 


Flags 
Instruction 
Addressing Modes 
S 
Z 
H PN N 
C 
Operation 


OR [A,]src 
src = R,RX,IM,IR,DA, 
t 
t 
0 
P 
0 
0 
OR 


X,SX,RA,SR,BX 
A - A OR src 


SBC [A,]src 
src = R,RX,IM,IR,DA, 
t 
t 
t 
v 
t 
Subtract With Carry 
X,SX,RA,SR ,BX 
(Byte) 


A -A - 
src - 
c 


SUB [A,]src 
src = R,RX,IM,IR,DA, 
t 
t 
t 
V 
t 
Subtract 
X,SX,RA,SR ,BX 
A -A - 
src 


XOR [A,]src 
src = R,RX,IM,IR,DA, 
t 
t 
0 
P 
0 
0 
Exclusive OR 
N eo 


X,SX,RA,SR,BX 
A -AXOR src 
8 
II 


16·Bit Arithmetic. Operations 
d 


Flags 
Instruction 
Addressing Modes 
S 
Z 
H PN N 
C 
Operation 


ADC dst,src 
dst= HL 
t 
t 
t 
v 
0 
t 
Add With Carry (Word) 
src = BC,DE,HL,SP 
dst - 
dst + src + c 
or 
dst= IX 
src = BC,DE,IX,SP 


or 
dst= IY 
src = BC,DE,IY,SP, 


ADD dst,src 
dst= HL 
• 
• 
t 
• 
0 
t 
Add (Word) 
src = BC,DE,HL,SP 
dst - 
dst + src 
or 
dst= IX 
src = BC,DE,IX,SP 


or 
dst= IY 
src = BC,DE,IY,SP 


ADD dst,A 
dst = HL,IX,IY 
t 
t 
t 
V 
0 
t 
Add Accumulator to 
Addressing Register 


dst - dst + A 


ADDW [HL,]src 
src = RR*,IM,DA,X,RA 
t 
t 
t 
V 
0 
t 
Add Word 


HL - 
HL + src 


CPW [HL,]src 
src = RR*,IM,DA,X,RA 
t 
t 
t 
V 
t 
Compare (Word) 


HL - 
src 


DECW dst 
dst= RR*,IR,DA,X,RA 
• 
• 
• 
• 
• 
• 
Decrement (Word) 


dst - 
dst - 
1 


'In X addressing mode, (HL + nn) is precluded. 
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16·Bit Arithmetic Operations (Continued) 


Flags 
Instruction 
Addressing Modes 
S 
Z 
H PN N 
C 
Operation 


DEC[W] dst 
dst= RR 
• 
• 
• 
• 
• 
• 
Decrement (Word) 


dst - 
dst - 
1 


DIVUW 
src = RR,IM,DA,X,RA 
0 
t 
• 
t 
• 
• 
Divide Unsigned (Word) 
[DEHL,]src 
HL - 
DEHL+ src 
DE - 
remainder 


DIVW [DEHL,]src 
src = RR,IM,DA,X,RA 
t 
t 
• 
t 
• 
• 
Divide (Word) 


HL - 
DEHL+ src 
DE - 
remainder 


EXTS HL 
• 
• 
• 
• 
• 
• 
Extend Sign (Word) 


If H(7)= 0, then DE - 
0000 
else' DE - FFFF 


INCW dst 
dst = RR,IR,DA,X*,RA 
• 
• 
• 
• 
• 
• 
Increment (Word) 


dst - 
dst + 1 


INC[W] dst 
dst= RR 
• 
• 
• 
• 
• 
• 
Increment (Word) 


dst - 
dst + 1 


MULTUW [HL,]src 
src = RR,IM,DA,X,RA 
0 
t 
• 
0 
• 
t 
Multiply Unsigned 
(Word) 


DEHL - 
HL x src 


MULTW [HL,]src 
src = RR,IM,DA,X,RA 
t 
t 
• 
0 
• 
t 
Multiply (Word) 


DEHL - 
HL x src 


NEG HL 
t 
t 
t 
V 
t 
Negate HL 


HL - 
-HL 


SBC dst,src 
dst= HL 
t 
t 
t 
V 
t 
Subtract With Carry 
src = BC,DE,HL,SP 
(Word) 


or 
dst - 
dst - 
s rc - 
C 


dst= IX 
src = BC,DE,IX,SP 


or 
dst= IY 
src = BC,DE,IY,SP 


SUBW [HL,]src 
src = RR,IM,DA,X*,RA 
t 
t 
t 
V 
t 
Subtract (Word) 


HL - 
HL - 
src 


·In X addressing mode, (HL + nn) is precluded. 
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Bit Manipulation, Rotate and Shift Group 


Flags 
Instruction 
Addressing Modes 
S 
Z 
H PN N 
C 
Operation 


BIT b,dst 
dst = R,IR,SX 
• 
~ 
• 
0 
0 
Bit Test 


Z - 
NOT dst(b) 


RES b,dst 
dst = R,IR,SX 
• 
• 
• 
• 
• 
• 
Reset bit 


dst(b) - 
0 


RL dst 
dst = R,IR,SX 
~ 
~ 
0 
p 
0 
~ 
Rotate Left 


tmp - 
dst 


dst(O) - 
C 
C - 
dst(7) 
N 
dst(n + 1) - 
tmp(n) for 
GO 


n = 0 to 6 
8 
L&EJJ - 
d 


dst 


RLA 
• 
• 
0 
• 
0 
Rotate Left Accumulator 


tmp-A 
A(O) - 
C 
C - 
A(7) 
A(n + 1) - 
tmp(n) for 
n = 0 to 6 
L&EJJ 


A 


RLC dst 
dst = R,IR,SX 
~ 
~ 
0 
p 
0 
Rotate Left Circular 


tmp - 
dst 


C - 
dst(7) 


dst(O) - 
tmp(7) 
dst(n + 1) - 
tmp(n) for 
n = 0 to 6 
~ 


dst 


RLCA 
• 
0 
0 
• 
0 
Rotate Left Circular 
(Accumulator) 


tmp-A 
C - 
A(7) 


A(O) - 
tmp(7) 
A(n + 1) - 
tmp(n) for 
n = 0 to 6 
~ 


A 
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Bit Manipulation, Rotate and Shift Group (Continued) 


Flags 


Instruction 
Addressing Modes 
S 
Z 
H PN N 
C 
Operation 


RLD 
~ 
~ ·0 
p 
0 
• 
Rotate Left Digit 


tmp(0:3) - 
A(0:3) 
A(0:3) - 
src(4:7} . 
src(4:7) - 
src(0:3) 
src(0:3) - 
tmp(O:3) 


17 4132J 801 


A 
dst 


RR dst 
dst = R,IR,SX 
~ 
~ 
0 
p 
0 
~ 
Rotate Right 


tmp - 
dst 
dst(7) - 
C 
C - 
dst(O) 
dst(n) - 
tmp(n + 1} for 
n = 0 to 6 
L[GJ-.@]J 


dst 


RRA 
• 
• 
0 
• 
0 
~ 
Rotate Right 
(Accumulator) 


tmp - 
dst 
A(7) - 
C 
C - 
A(O) 
A(n) - 
tmp(n + 1) for 
n = 0 to 6 
Lo-liJ 


A 


RRC dst 
dst= R,IR,SX 
~ 
~ 
0 
p 
0 
~ 
Rotate Right Circular 


tmp - 
dst 


C - 
dst(O) 
dst(7) - 
tmp(O} 
dst(n) - 
tmp(n + 1) for 
n = 0 to 6 
L[G}l0 


.dst 
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Bit Manipulation, Rotate and Shift Group (Continued)' 


Flags 


Instruction 
Addressing Modes 
S 
Z 
H PN N 
C 
Operation 


RRCA 
• 
• 
0 
• 
0 
Rotate Right Circular 
(Accumulator) 


tmp -A 
C - 
A(O) 
A(7) - 
tm p(O) 
A(n) - 
tmp(n + 1) for 
n = 0 to 6 
LG4J 


dst 
N = 
RRD dst 
dst=IR 
t 
t 
0 
p 
0 
• 
Rotate Right Digit 
8 


tmp(O:3) - 
A(O:3) 
E{ 


A(O:3) - 
src(O:3) 
tg 


src(O:3) - 
src(4:7) 
c= 


src(4:7) - 
tmp(O:3) 


17 <13B gol 


A 
dst 


SET b,dst 
dst = R,IR,SX 
• 
0 
0 
0 
• 
• 
Set Bit 


dst(b) - 
1 


SLA dst 
dst = R,IR,SX 
t 
t 
0 
p 
0 
t 
Shift Left Arithmetic 


tmp - 
dst 


C - 
dst(7) . 
dst(O) - 
0 


dst(n + 1) - 
tmp(n) for 
n = 0 to 6 
0~~o 


dst 


SRA dst 
dst = R,IR,SX 
t 
t 
0 
p 
0 
t 
Shift Right Arithmetic 


tmp - 
dst 


C - 
dst(O) 
dst(7) - 
tmp(7) 
dst(n) - 
tmp(n + 1) for 
n = 0 to 6 
~ 


dst 


611 


Bit Manipulation, Rotate and Shift Group (Continued) 


Flags, 
Instruction 
Addressing Modes 
S 
Z 
H PN N 
C 
Operation 


SRL dst 
dst = R,IR,SX 
0 
~ 
0 
p 
0 
~ 
Shift Right Logical 


tmp - dst 
C - 
dst(O) 


dst(7) - 
0 


dst(n) - tmp(n + 1) for 
n = 0 to 6 
O~~ 


dst 


TSET dst 
dst = R,IR,SX 
~ 
• 
• 
• 
• 
• 
Test and Set 


s - 
dst(7) 
dst - 
FF 


Program Control Group 


Flags 
Instruction 
Addressing Modes 
S 
Z 
H PN N 
C 
Operation 


CALL cC,dst 
dst = IR,DA,RA 
• 
• · 
. 
• 
• 
• 
CALL 


If cc is satisfied then: 


SP - 
SP - 
2 


(SP) - 
PC 
PC - 
dst 


CALL dst 
dst = IR,DA,RA 
• 
• 
• 
• 
• 
• 
CALL 


SP - 
SP - 
2 


(SP) - 
PC 
PC - 
dst 


CCF 
• 
• 
~ 
• 
0 
~ 
Complement Carry Flag 


C - 
NOTC 


DJNZ dst 
dst= RA 
• 
• 
• 
• 
• 
• 
Decrement and Jump if 
Non·Zero 
8-8-1 
If 8=#=0 then PC - 
dst 


JAF dst 
dst= RA 
• 
• 
• 
• 
• 
• 
Jump on Auxiliary 
Accumulator/Flag 


If Auxiliary AF then: 


PC - 
dst 


JAR dst 
dst= RA 
• 
• 
• 
• 
• 
• 
Jump on Auxiliary 
Register File in Use 


If Auxiliary File then: 


PC - 
dst 


JP cC,dst 
dst = IR,DA,RA 
• 
• 
• 
• 
• 
• 
Jump 


If cc is satisfied then: 


PC - 
dst 
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Program Control Group (Continued) 


Flags 
Instruction 
Addressing Modes 
S 
Z 
H PM 
N 
C 
Operation 


JP dst 
dst = IR,DA,RA 
• 
• 
0 
• 
• 
• 
Jump 


PC - 
dst 


JR ee,dst 
dst= RA 
• 
• 
• 
• 
0 
0 
Jump Relative 


If ee* is satisfied then: 
PC - 
PC + dst 


JR dst 
dst= RA 
• 
0 
0 
0 
0 
0 
Jump Relative 


PC - 
PC + dst 


RET 
0 
0 
0 
0 
0 
• 
Return 
N 
00 


PC - 
(SP) 
8 


SP - 
SP - 
2 
iI 


RET ee 
• 
0 
0 
0 
• 
0 
Return 
a 


If ee is satisfied then: 


PC - 
(SP) 
SP - 
SP + 2 


RST dstt 
dst= DA 
• 
0 
0 
0 
0 
• 
Restart 


SP - 
SP - 
2 
(SP) - 
PC 
PC - 
dst 


SC nn 
0 
• 
• 
0 
0 
• 
System Call 


SP -SP - 
4 
(SP) - 
PS 
SP - 
SP - 
2 
(SP) - 
nn 
PS - 
System Call 


Program Status 


SCF 
• 
0 
0 
• 
0 
Set Carry Flag 


C-1 


Input/Output Instruction Group 


Flags 
Instruction 
Addressing Modes 
S 
Z 
H PM 
N 
C 
Operation 


* 
IN dst,(C) 
dst= R,RX,DA,X,RA, 
0 
P 
0 
0 
Input 


SR,BX 
dst - 
(C) 


* 
IN A,(n) 
• 
• 
• 
• 
• 
• 
Input Accumulator 


A - 
(n) 


• Uses abbreviated set of condition codes. 
t dst mustbe 0, 8, 16, 24, 32, 40, or 56. 


:j: Programmable as privileged. 
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Input/Output Instruction Group (Continued) 


Flags 
Instruction 
Addressing Modes 
S 
Z 
H PN N 
C 
Operation 


t 
IN[W] HL,(C) 
• 
• 
• 
• 
• 
• 
Input HL 


HL - 
(C) 


t 
IND 
• 
• 
• 
• 
Input and Decrement 
(Byte) 


(HL) - 
(C) 
8-8-1 
HL-HL-'1 


t 
INDW 
• 
• 
• 
• 
Input and Decrement 
(Word) 


(HL) - 
(C) 
8-8-1 
HL - 
HL - 
2 
t INDR 
• 
1 
• 
• 
• 
Input, Decrement and 
Repeat (Byte) 


Repeat until 8 = 0: 


HL - 
(C) 
8-8-1 
HL - 
HL - 
1 
t INDRW 
• 
1 
• 
• 
• 
Input, Decrement and 
Repeat (Word) 


Repeat until 8 = 0: 


HL - 
(C) 
8-8-1 
HL - 
HL - 
2 


t INI 
• 
t 
• 
• 
• 
Input and Increment 
(Byte) 


(HL) - 
(C) 
8-8-1 
HL - 
HL + 1 
t INIW 
• 
t 
• 
• 
• 
Input and Increment 
(Word) 


(HL) - 
(C) 
8-8-1 
HL - 
HL + 2 
t INIR 
• 
• 
• 
• 
Input, Increment and 
Repeat (Byte) 


Repeat until 8 = 0: 


(HL) - 
(C) 
HL - 
HL + 1 
8-8-1 


t Programmable as privileged. 
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Input/Output Instruction Group (Continued) 


Flags 


Instruction 
Addressing Modes 
S 
Z 
H PN N 
C 
Operation 


t INIRW 
0 
0 
0 
0 
Input, Increment and 
Repeat (Word) 


Repeat until B = 0: 


(HL) - 
(C) 
HL - 
HL - 
2 
B-B-1 


tOUT (C),src 
src= R,RX,DA,X,RA, 
0 
0 
0 
0 
0 
0 
Output 


SR,BX 
(C) - 
src 


tOUT (n),A 
0 
0 
0 
0 
0 
0 
Output Accumulator 
~-J 
~ 


(n) - 
A 
~ 
~ 
~ 


t OUT[W] (C),HL 
0 
0 
0 
0 
0 
0 
Output HL 
t-J 
'U 


(C) - 
HL 


e;I 


t OUTD 
0 
t 
0 
0 
• 
Output and Decrement 
(Byte) 
B-B-1 
(C) - 
(HL) 
HL - 
HL - 
1 


t.OUTDW 
0 
t 
0 
0 
0 
Output and Decrement 
(Word) 
B-B-1 
(C) - 
(HL) 
HL - 
HL - 
2 


t OUTDR 
0 
0 
• 
0 
Output, Decrement and 
Repeat ,(Byte) 


Repeat until B = 0: 


B - B-1 ' 
(C) - 
(HL) 
HL - 
HL - 
1 


t OUTDRW 
0 
0 
0 
0 
Output, Decrement and 
Repeat (Word) 


Repeat until B = 0: 
B-B-1 
(C) - 
(HL) 
HL- HL- 2 


t OUTI 
• 
t 
0 
0 
0 
Output and Increment 
(Byte) 
B-B-1 
(C) - 
(HL) 
HL - 
HL + 1 


t Programmable as privileged. 
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Input/Output Instruction Group (Continued) 


Flags 


Instruction 
Addressing Modes 
S 
Z 
H PN N 
C 
Operation 


t OUTIW 
• 
~ 
• 
• 
• 
Output and Increment 
(Word) 
B-B-1 
(C) - 
(HL) 
HL - 
HL + 2 


t OUTIR 
• 
• 
• 
• 
Output, Increment and 
Repeat (Byte) 


Repeat until B = 0: 
B-8-1 
(C) - 
(HL) 
HL - 
HL + 1 
t OUTIRW 
• 
• 
• 
• 
Output, Increment and· 
Repeat (Word) 


Repeat until B = 0: 
B-B -- 1 
(C) - 
(HL) 
HL - 
HL + 2 
t TSTI (C) 
~ 
~ 
0 
P 
0 
• 
Test Input 


F - 
test (C) 


CPU Control Group 


Flags 


Instruction 
Addressing Modes 
S .Z 
H PN N 
C 
Operation 


* Dllnt 
Int = E6,E5,E4,E3,E2, 
• 
• 
• 
• 
• 
• 
Disable Interrupt 
E1,EO 
If Ei then: 
MSR(i) - 
0; 


Otherwise 


MSRO _ 6 - 
0 


* Ellnt 
Int = E6,E5,E4,E3,E2, 
• 
• 
• 
• 
• 
• 
Enable Interrupt 
E1,EO 
If Ei then: 
MSR(i) ;,.... 1; 
Otherwise 


MSRO _ 6 - 
1 


* HALT 
0 
\ 
0 
• 
• 
• 
• 
Halt 


CPU Halts 


* 1M p 
p=0,1,2,3 
0 
0 
0 
0 
0 
0 
Interrupt Mode Sel~ct 


Interrupt Mode - 
p 


* LD dst,src 
dst=A 
0 
0 
• 
Load Accumulator from 
src = I,R 
I or R Register 


A - 
src 
t Programmable as privileged. 
• Privileged Instruction. 
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CPU Control Group (Continued) 


Flags 
Instruction 
Addressing Modes 
S 
Z 
H PN N 
C 
Operation 


* LO dst,src 
dst= I,R 
0 
• 
0 
0 
• 
0 
Load I or R Register 
src=A 
from Accumulator 


dst - 
A 


* LOCTL dst,src 
dst = (C), USP 
• 
• 
• 
• 
• 
• 
Load Control 
src = HL,IX,IY 
dst - 
src 
or 
dst = HL,IX,IY 
src = (C),USP 


NOP 
• 
0 
• 
• 
• 
• 
No Operation 


e-.:l 


PCACHE 
Purge Cache 
m 
• 
• 
• 
• 
• 
• 
~ 


All cache entries 
S 


~ 
invalidated 
~ 
eJ 


* RETI 
0 
• 
• 
0 
0 
• 
Return from Interrupt 


PC - 
(SP) 
SP - 
SP + 2 


* RETIL 
• 
0 
• 
0 
• 
0 
Return from Interrupt 
Long 


PS - 
(SP) 
SP - 
SP + 4 


* RETN 
• 
• 
• 
0 
• 
0 
Return from 
Nonmaskable Interrupt 


PC - 
(SP) 
SP - 
SP + 2 


MSR(O-7) - 
IFF(O-7) 


Extended Instruction Group1 


Flags 
Instruction 
Addressing Modes 
S 
Z 
H PM 
N 
C 
Operation 


EPUM src 
src = IR,DA,X,RA,SR,BX 
• 
• 
0 
• 
• 
• 
Load EPU from Memory 


EPU - 
template 


EPU - 
src 


MEPU dst 
dst = IR,DA,X,RA,SR,BX 
0 
0 
0 
• 
• 
• 
Load Memory from EPU 


EPU - 
template 
dst - 
EPU 


EPUF 
~ 
~ 
0 
P 
0 
• 
Load Accumulator 
from EPU 


EPU - 
template 


A-EPU 


EPUI 
• 
• 
• 
• 
• 
• 
EPU Internal Operation 


EPU - 
template 


1 Refer to the Z8070 Z8000™ Floating-Point Product Specification (document number 00-2235-01) for the floating-point 
extended instructions. 


• Privileged instruction. 
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EXTENDED PROCESSING 
ARCHITECTURE 


Features, 


The Zilog Extended Processing Architecture (EPA) pro- 
vides an extremely flexible and modular approach to ex- 
panding both the hardware and software capabilities of 
the Z800 CPU. Features of the EPA includ~: 


II Allows Z800 CPU instruction set to be extended by 


external devices. 


III 
Increases throughput of the system by using up to 
-four specialized external processors in parallel with 
the CPU. 


EI 
Used by Z8070 floating-point EPU. 


II Permits 
modular design of Z800 
CPU-based 


systems. 


II Provides 
easy 
management 
of 
multiple 


microprocessor configurations via "single instruc- 
tion stream" communication. 


D 
Simple interconnection between EPUs and Z800 
MPU requires no additional external supporting 
logic. 


II Supports debugging of suspect hardware against 
proven software. 


m EPUs can be added as the system grows and as 


EPUs with specialized functions are developed. 


General Description 


The processing power of the Zilog Z-BUS Z800 
microprocessor can be boosted beyond its intrinsic 
capability by the Extended Processing Architecture 
(EPA). The EPA allows the Z800 CPU to accommodate 
up to four Extended Processing Units (EPUs), which per- 
form specialized functions in parallel with the CPU's 
main instruction execution stream. 


The EPUs connect directly to the Z-BUS and continuous- 
ly monitor the CPU instruction stream for an instruction 
intended for the EPU (template). When a template is 
detected, the appropriate EPU responds, obtaining or 
placing data or status information on the Z-BUS by using 
the Z800 CPU-generated control signals and performing 
its function as directed. 


The CPU is responsible for instructing the EPU and 
delivering operands and data to it. The EPU recognizes 
templates intended for it and executes them, using data 
supplied with the template and/or data within its internal 
registers. There are three classes of EPU instructions: 


m Data transfers between main memory and EPU 


registers 


11 
Data transfers between CPU registers and EPU 
status registers 


II 
EPU internal operations 
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Six addressing modes can be utilized with transfers be- 
tween EPU registers and the CPU and main memory: 


II Direct Address 


II 
Indirect Register 


• 
Indexed 


• 
Stack Pointer Relative 


II Relative 


• 
Base Index 


In addition to the hardware-implemented capabilities of 
the 
EPA, 
there 
is 
an 
extended instruction trap 
mechanism to permit software simulation of EPU func- 
tions. An EPU present bit in the Z800 MPU T"rap Control- 
register indicates whether actual EPUs are present or 
not. If not, when the CPU traps when an extended in- 
struction is detected, a software "trap -handler" can 
emulate the desired EPU function. Thus, the EPA soft- 
ware trap routine supports systems not. containing an 
EPU. 


EPA and CPU instruction execution are shown in Figure 
17. The CPU begins operation by fetching an instruction 
and determining whether or not it is an EPU instruction. 
If the instruction is an EPU instruction, the state of the 
EPU Enable bit in the Trap Control register is examined. 
If the EPU Enable bit is reset (E = 0), the CPU generates 
a trap and the EPU instruction can be simulated by an 
EPU instruction trap software routine. However, if the 
EPU Enable bit is set (E = 1), indicating that an EPU is 
present in the system, then the 4-byte EPU template is 
fetched from memory. The fetching of the EPU template 
is indicated by the status lines STo-ST3. The EPU mean- 
while continuously monitors the Z-BUS and the status 
lines for its own templates. After fetching the EPU 
template, the CPU, if necessary, transfers appropriate 
data between the CPU and memory or between the CPU 
and the EPU. These transactions are indicated by unique 
encodings of the status lines. If the EPU is free when the 
template and the data appear, the EPU template is ex- 
ecuted. If the EPU is still processing a previous instruc- 
tion, it activates the PAUSE line (Z8216 only) to halt fur- 
ther execution of CPU instructions until execution is 
complete. After the execution of the template is com- 
plete, the EPU deactivates the PAUSE line and CPU in- 
struction. execution continues. 


r-----------' 
I 
I 
NO 


YES I 
CPU FETCHES 
EPU TEMPLATE 
FROM MEMORY 
I , I 
I 
I 
I 
I 
I 


CPU GENERATES 
DATA/ADDRESS 


AND PLACES 
ON Z·BUS 
1-. __________ _ 


~------------~--------2---------~ 
SET PAUSE 
LINE AT CPU 


UNTIL EPU 
FREE 


Figure 17. EPA and Z8216 CPU Instruction Execution 


MEMORY MANAGEMENT 


Features 


• 
On-chip dynamic address translation 


• 
Permits addressing of large physical memory 
o 512K bytes-40-pin devices 
o 
16M bytes-64-pin devices 


• 
Separate translation facilities for user and system 
modes 


• 
Permits instructions and data to reside in separate 
memory areas. 


• 
Write prote'ction for individual pages of memory 


• 
Aborts CPU on access violation to support virtual 
memory 


General Description 


Th.e Z800 microprocessor contains an on-chip Memory 
Management Unit (MMU), which translates logical ad- 
dresses into physical addresses. This allows access to 
more than 64K bytes of physical memory and provides 
memory protection features typical of those found on 
large systems. With the MMU, the CPU can access up to 
16M bytes of physical memory, depending on package 
size (the 40-pin package devices output only 19 address 
bits). The MMU features a sophisticated trapping 
mechanism that generates page fault$ on error condi- 
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tions. Instructions that are aborted by a page fault can 
be restarted in a manner compatible with virtual memory 
system requirements. On reset, the MMU features are 
not enabled, thus permitting logical addresses to pass to, 
the physical memory untranslated. 


The physical address space is expanded by dividing the 
64K byte logical address space (the space manipulated 
by the program) into pages. The pages are then mapped 
(translated) into the larger physical address space of the 
Z800 microprocessor. The mapping process makes the 
user software addresses independent of the physical 
memory, so the user is freed from specifying where in- 
formation is actually stored in physical memory. The ac- 
tual size of the page depends on whether the pro- 
gram/data separation mode is enabled-if it is enabled, 
each page is 8K bytes in length, and if it is not enabled, 
the page length is 4K bytes. With the page mapping 
technique, 16-bit logica'i addresses can be translated in- 
to 24-bit physical addresses (only the lower 19 bits are 
externally available on 40-pin devices). Address transla- 
tion can occur both in system arid in user mode, with 
separate translation facilities available to each mode. 
The MMU further allows instruction references to be 
separated from data references, which enables pro- 
grams of up to 64K bytes in length to manipulate up to 
64Kbytes of data without operating system intervention. 
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MMU Architecture 


The Z800 MMU consists of two sets of sixteen page 
descriptor registers (Figure 18) that are used to translate 
addresses, a 16-bit control register that governs the 
translati.on facilities, a Page Descriptor Register Pointer, 
an I/O write-only port that can be used to invalidate sets 
of page descriptors, and two I/O ports for accesses to 
the page descriptor registers. One set of page descriptor 
registers is dedicated to the system mode of operation 
and the other set is dedicated to the user mode of opera- 
tion. 


While an address is being translated, attributes 
associated with the logical page containing that location 
are checked. The correct logical page is determined by 
the CPU mode (user or system), address space (pro- 
gram/data), and the four most significant bits of the 
logical address. Pages can be write-protected to prevent 
them from being modified by the executing task and can 
also be marked as non-cacheable to prevent information 
from being copied into the cache for later reference. The. 
latter capability is useful in multiprocessor systems, to 
ensure that the processor always accesses the most 
current version of information being shared among multi- 
ple devices. The MMU also maintains a bit for each page 
that indicates if the page has been modified. 


Each page descriptor register contains a Valid bit, which 
indicates that the descriptor contains valid information. 
Any attempt by the MMU to translate an address using 
an invalid descriptor generates a page fault. Valid bits for 
groups of page descriptor registers can be reset- by 
writing to an MMU control port. 


15 
o 


Figure 18. Page Descriptor Register 


For each mode of CPU operation, the MMU can be con- 
figured to separate instruction fetches from data 
fetches, and thus separate the program address space 
from the data address space. When the program/data 
separation mode is in effect, the·sixteen page descriptor 
registers for the current CPU mode of operation (user or 
system) are partitioned into two sets, one for instruction 
fetches and one for data fetches. A instruction fetch or 
data access using the Program Counter Relative ad- 
dressing mode is translated by the MMU registers 
associated with the program address space; data ac- 
cesses using ,other addressing modes .and accesses to 
the Interrupt Vector Table in interrupt mode 2 use the 
MMU registers associated with the data address space. 
In this mode of MMU operation, the page size is 8192 
bytes. There are two control bits in the MMU Master 
Control register that independently specify whether the 
user and system modes of CPU operation have separate 
program and data address spaces. 
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Each 16-bit page descriptor register consists of a 4-bit 
attribute field and a 12-bit page frame address field. The 
attribute field consists of the least Significant bits of the 
descriptor and contains four control and status bits, 
listed below. 


Modified (M). This bit is automatically set whenever a 
write is successfully performed to a logical address in 
this page; it can be cleared to ° only by a software 
routine that loads the descriptor register. If the Valid bit 
is 0, the contents of this bit are undefined. 


Cacheable (C). While this bit is set to 1, information 
fetched from this page can be placed in the cache. While 
this bit is cleared to 0, the cache control mechanism is 
inhibited from retaining a copy of the information. 


Write-Protect (WP). While this bit is set to 1, CPU writes 
to logical addresses in this page cause a page fault to be 
gener?ted and prevent a write operation from occurring. 
While this bit is cleared to 0, all valid accesses are per- 
mitted. 


Valid (V). While this bit is set to 1, the descriptor contains 
valid information. While this bit is cleared to 0, all CPU 
accesses to logical addresses in this page cause a page 
fault to be generated. 
' 


MMU Control Registers and 110 Ports 


MMU operation is controlled by one control register and 
four dedicated I/O ports. The MMU Master Control 
register (Figure 19) determines the program/data ad- 
dress space separation in effect in both user and system 
modes and whether logical addresses generated in user 
and system mode will be translated by the MMU. Page 
descriptor registers are accessed indirectly through the 
register address contained in the Page Descriptor 
Register Pointer. The descriptor select port is used to ac- 
cess the page descriptor register that is pOinted to by the 
Page Descriptor Register Pointer. After this access the 
Page Descriptor Register Pointer is left unchanged. The 
block move I/O port is used to move blocks of words be~ 
tween the page descriptor registers and memory; reads 
or writes to this I/O port access data pointed to by the 
Page Descriptor Register Pointer, then increment the 
pointer by one. The Invalidation I/O Port is used to in- 
validate blocks of page descriptor registers; writes to 
this port cause the Valid bits in selected blocks of page 
descriptor registers to be cleared to 0, which indicates 
that the descriptors no longer contain valid information. 


15 
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Figure 19. MMU Master Control Register 


MMU Master Control Register. The MMU Master Con- 
trol register controls the operation of the MMU. This 
register contains four control bits; all other pits in this 
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register must be cleared to O. The four control bits of the 
MMU Master Control register are described below. 


Page Fault Identifier (PFI). This 5-bit field latches infor- 
mation that indicates which page descriptor register was 
being accessed when 
the access violation was 
detected. 


System Mode Program/Data Separation Enable (SPD). 
While this bit is set to 1, instruction fetches and data ac- 
cesses via the PC Relative addressing mode use the 
system mode page descriptor registers 8-15, and data 
references that do not use the PC Relative addressing 
mode use the system mode page descriptor registers 
0-7. While this bit is cleared to 0, system mode page 
descriptor registers 0-15 are used to translate instruc- 
tion and data references. 


System Mode Translate Enable (STE). While this bit is set 
to 1, logical addresses generated in the system mode of 
operation are translated. While this bit is cleared to 0, 
addresses are passed through the MMU extended with 
zeros in the most significant bits and no attribute check- 


o ing or modified bit setting is performed. 


User Mode Program/Data Space Separation Enable 
(UPD). While this bit is set to 1, instruction fetches and 
data accesses via the PC Relative addressing mode use 
user mode page descriptor registers 8-15, and data 
references that do not use the PC Relatiye addressing 
mode use user mode page descriptor registers 0-7. 
While this bit is cleared to 0, user mode page descriptor 
registers 0-15 are used to translate instruction and data 
references. 


User Mode Translated Enable (UTE). While this bit is set 
to 1, logical addresses generated in the user mode of 
operation are translated. While this bit is cleared to 0 
addresses are passed through the MMU extended with 
. zeros in the most significant bits and no attribute check- 
ing or modified bit setting is performed. 


0 


Page Descriptor Register Pointer. Moves of data into 
and out of the MMU page descriptor registers use the 
Page Descriptor Register Pointer. This 8-bit register con- 
tains the address of one of the page descriptor registers. 
When a word 110 instruction accesses 110 address 
FFxxF5 (descriptor select port), this register is used to 
access a page descriptor register. When a word 110 in- 
struction accesses 110 address FFxxF4 (block move 110 
port), this register is also used to access a page descrip- 
tor register, but after the access, this register is 
automatically incremented by one. 


Descriptor Select Port. Moves of on'e word of data into 
and out of a page descriptor register are accomplished 
by writing and reading words to or from this dedicated 
110 port at location FFxxF5. Any word 110 instruction can 
be used to access a page descriptor register via this 
port, provided that the Page Descriptor Register Pointer 
is properly initialized. 


Block Move I/O Port. Block moves of data into and out 
of the page descriptor registers are accomplished by 
writing and reading words to or from this dedicated 110 
port at location FFxxF4. Any word I/O instruction can be 
used to access page descriptor registers via this port, 
provided that the Page Descriptor Register Pointer is 
properly initialized. 


Invalidation I/O Port. Valid bits can be cleared (i.e., the 
page descriptor registers invalidated) by writing to this 
dedicated 8-bit port {Table 3). Individual Valid bits can 
subsequently be set by software writing to the page 
descriptor registers. Reading this I/O port returns un- 
predictable data. 


Encoding 


Table 3. Invalidation Port Table 


Registers Invalid 


System Page Descriptor Registers 0-7 
System Page Descriptor Registers 8-15 
System Page Descriptor Registers 0-15 
User Page Descriptor Registers 0-7 
User Page Descriptor Registers 8-15 
User Page Descriptor Registers 8-15 
User Page Descriptor Registers 0-15 


Translation Mechanism 


Address Translation. Address translation is illustrated 
in Figure 20. While the Program/Data Space Separation 
bit is cleared to 0, the 16-bit logical address is divided in- 
to two fields, a 4-bit index field used to select one of 16 
page descripto~ registers, and a 12-bit offset field that 
forms the lower 12 bits of the physical address. The 
physical address is composed of the 12-bit page frame 
address supplied by the selected page descriptor 
register and the 12-bit offset supplied by the logical ad- 
dress. 


While the ProgramlData Space Separation bit is set to 1, 
the logical address is divided into a 3-bit index field and a 
13-bit offset field. The page descriptor register consists 
of an 11-bit Page Frame Address field. The physical ad- 
dress is a result of concatenating the page frame ad- 
dress and the logical offset. The page descriptor register 
. is chosen by a 4-bit index field, which consists of a Pro- 
. gram/Data Address bit from the CPU and the three Index 


bits from the logical address. 
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Figure 20. Address Translation 


ON-CHIP MEMORY 


Features 


• 
256-byte local memory 


• 
Configurable as high-speed cache 


• 
Programmable to cache instructions, data or both 


• 
Permits faster execution by minimizing external bus 
accesses 


• 
Operation is transparent to user 


• 
Configurable as local RAM with user-definable ad- 
dresses 


The Z800 MPU has 256 bytes of on-chip memory, which 
can be dedicated to memory locations programmed by 


the system or used as a cache for instructions or data. 
Its. mode of use (dedicated memory or a cache) is pro- 
grammable; on reset it is automatically enabled for use 
as a cache for instructions only. 


On·Chip Memory Architecture 


The on-chip memory is organized as 16 lines of 16 bytes 
each. Each line can hold a copy of 16 consecutive bytes 
in physical memory locations whose 20 most significant 
bits of physical address are identical. Each byte in the 
cache has an associated Valid bit that indicates whether 
the cache holds a valid copy of the memory contents at 
the associated physical memory location. Figure 21 illus- 
trates the cache organization_ 


20 BITS 
16 BITS 
16 x 8 BITS 


LINE 0 


LINE 1 


LINE 2 


• 


LINE 15 
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TAG 0 
VALID 
CACHE DATA 
BITS 


TAG 1 
VALID 
CACHE DATA 
BITS 


TAG 2 
VALID 
CACHE DATA 
BITS 
• 
• 
• 
• 
• 
• 
• 
• 
• 


TAG 15 
VALID 
CACHE DATA 
BITS 


Tag n = the 20 Address bits associated with line n 
Valid bits = 16 bits that Indicate which bytes In the cache contain valid data 
Cache data = 16 bytes 


Figure 21. Cache Organization 
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The on-chip memory has two modes of operation. If the 
Memory/Cache bit in the Cache Control register is set to 
1, then the 256 bytes of on-chip memory are treated as 
physical memory locations. Memory accesses to ad- 
dresses covered by the on-chip memory do not generate 
bus transactions on the external bus and hence the ac- 
cesses are faster. In this mode, the valid bits are ig- 
nored. 


If the Memory/Cache bit is cleared to 0, then the 256 
bytes of on-chip memory are treated as a cache 
memory. The lines are allocated using a least-recently 
used (LRU) algorithm. When a cache "miss" on a read 
occurs (and the MMU does not assert cache inhibit), the 
line in the cache that has been least recently accessed 
is selected to hold the newly read data. All bytes in the 
selected line are marked invalid except for the bytes 
containing the newly accessed data. On a cache miss, 
one or two bytes, depending on the bus size, are fetched 
from main memory. Except for burst mode instruction 
fetches, the cache does not pre-fetch beyond the 
currently-requested address. A cache miss on a data 
write does not cause a line to be allocated to the 
memory location accessed. 


The cache can hold both instructions and data. Two con- 
trol bits in the Cache Control register can be separately 
set to enable the cache to hold instructions and to hold 
data. If the cache contains data, writes to data at loca- 
tions contained in the cache also cause external bus 
transactions to update the appropriate memory location. 


Both the CPU and the on-chip DMAs access the cache. 
For the CPU, if the MMU is enabled, the access can be 
either cacheable or non-cacheable, depending on the 
value of the Cacheable bit in the page descriptor register 
used to translate the logical address. If the MMU is not 
enabled, all memory transactions are considered to be 
cacheable. Two bits in the Cache Control register, the 
Cache Instruc.tions Disable bit and the Cach~ Data 
Disable bit, further determine the operation of the cache_ 
for various situations. These bits enable the cache for in- 
structions and for data. 


When the on-chip memory is used as fixed memory loca- 
tions, neither the Cache Instruction Disable or Cache 
Data Disable bits are used, and no distinction is made as 
to whether the CPU is accessing data or instructions. 


In general, when devices such as on-chip DMAs transfer 
data to the memory, the cache data is modified if the 


CLOCK OSCILLATOR 


The Z800 MPU has an on-chip clock oscillator/generator 
that can be connected to a crystal or any suitable clock 
source. The bus timing clock generated from the on-Chip 
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wdte is to a valid location in the cache but the LRU 
mechanism is unaffected. Also, for the EPU to memory 
transfer, if the cache contains valid locations that are up- 
dated by an EPU transaction, the on-chip cache is also 
updated. 


Cache Control Register. The operation of the on-chip 
memory is controlled by an 8-bit Cache Control register 
(Figure 22) that is accessed using a load control instruc- 
tion. This register contains five control bits; all other bits 
must be cleared to o. 
- 


7 
0 
IM/cl I I 0 ILMBEBI 0 I 0 I 0 I 


Figure 22. Cache Control Register 


The bits in this register are: 


High Memory Burst Capability (HMB). This 1-bit field 
specifies whether a memory burst transaction occurs 
when the MMU is enabled and there is a 1 in bit 15 of the 
selected page descriptor register (0 = burst mode not 
supported, 1 = burst mode supported). 


Low Memory Burst' Capability (LMB). This 1-bit field 
specifies whether' a memory burst transaction occurs 
when the MMU is disabled or when the MMU is enabled 
and there is a zero in bit 15 of the selected page descrip- 
tor register (0 = burst mode not supported, 1 = burst 
mode supported). 
' 


Cache Data Dis~b/e (D) . . While this bit is cleared to 0, 
data fetches are copied into the cache if the M/C bit = 0 
(cache mode). If M/C = 1, the state of this bit is ignored. 


Cache Instructions.Disable (/). While this bit is cleared to 
0, instruction fetches are copied into the cache when the 
M/C bit = 0 (cache mode). When M/C = 1, the state of 
this bit is ignored. 


Memory/Cache (M/C). While this bit is set to 1, the on- 
chip memory is to be accessed as phYSical memory; 
while it is cleared to 0, the memory is accessed \ 
associatively as a cache. 


If the on-chip memory is to be used as fixed memory 
locations, the user can programmably select the ranges 
of memory addresses for which the on-Chip memory 
responds. 


oscillator is output for use by the rest of the system. The 


f~eql.Jency of the processor clock is one-half that of the 
fundamental frequency of the crystal. 
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REFRESH 


The Z8aa MPU has an internal mechanism for refreshing 
dynamic memory. This mechanism can be activated by 
setting ·the Refresh Enable bit in the Refresh Rate 
register to 1. Memory refresh is performed periodically 
at a rate specified by the Refresh Rate register. Refresh 
transactions are identical to memory transactions ex- 
cept that different status signals are used and no data is 
transferred. They can be inserted immediately after the 
last clock cycle of any bus transaction, including an in- 
ternal operation. 


While the Refresh Enable bit is set to 1, the value of the 
6-bit Rate field in the Refresh Rate register determines 
the time between successive refreshes (the refresh 
period). When ·Rate = a, the refresh period is 256 pro- 
cessor clock cycles; when Rate = n (n > a) the refresh 
period is 4n. The Rate and Refresh Enable control bits 
are programmed via an I/O instruction. 


The refresh transaction is generated as soon as possible 
after the refresh period has elapsed (generally after the 
last clock cycle of the current bus transaction). If the 
CPU receives an interrupt request, the refresh operation 
is performed first. When the Z8aa CPU does not have 
control of the bus or is in the wait state, internal circuitry 
records the number of refresh periods that have elapsed 
and refresh cycles cannot be generated. When the CPU 
regains control of the bus or the Wait input signal is 
deactivated and the bus transaction completes, the 
refresh mechanism immediately issues the skipped 
refresh cycles. The internal circuitry can record up to 
256 such skipped refresh operations. 


UART 


The Z8aa UART transmits and receives serial data using 
any common asynchronous data-commun,ication pro- 
tocol. 


Transmission and reception can be performed in- 
dependently with five, six, seven, or eight bits per 
character, plus optional even or odd parity. The transmit- 
ter can supply one or two stop bits and can provide a 
break output at any time. Reception is protected from 
spikes by a "transient spike-rejection" mechanism that 
checks the ·signal one-half a bit time after a Low level is 
detected on the receiver data input; if the Low does not 
persist-as in the case of a transient-the character 
assembly process is not started. Framing errors and 
overruns are detected and buffered with the partial 
character on which they occur. Furthermore, a built-in 
checking process avoids interpreting a framing error as 
a new start bit: a framing error results in the addition of 
one-half a bit time to the point at which the search for the 
next start bit is begun. 


The UART uses the same clock frequency for both the 
transmitter and the' receiver. The input for the UART 
clocking circuitry is derived from counter/timer a, either 
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A 1 a-bit refresh address is generated for each refresh 
operation with the refresh address being incremented by 
two between refreshes for 16-bit bus versions, and by 
one for 8-bit bus versions. 


On reset, refresh is enabled, the rate is 32 processor 
clock cycles, and the refresh address is not affected. 


The Refresh mechanism is controlled by an 8-bit control 
register, described below. 


Refresh Rate Register. This 8-bit register (Figure 23) 
enables the refresh mechanism and specifies the fre- 
quency of refresh transactions. 


Figure 23. Refresh Rate Register 


The fields in this register are: 


Refresh (Rate). This field indicates in processor clock 
cycles the rate at which refresh transactions are to be 
generated; a value of n in this field indicates a refresh 
period of 4n, with Rate = a indicating 256 clock cycles. 


Refresh Enab/e (E). When this 1-bit field is set to 1, the 
refresh mechanism is enabled. 


from its external input line for an external clock or from 
the counter/timer output for a bit rate generatec,j from the 
internal processor clock. The UART input clock is further 
scaled by 1, 16, 32, or 64 for clocking the transmitter and 
receiver. 


Two of the DMA channels can be used independently to 
move characters between memory and the transmitter 
or receiver without CPU intervention. Both the transmit- 
ter and receiver can interrupt the CPU for processor 
assistance. 


The UART uses two external pins, Transmit and Receive. 
Data that is to be transmitted is placed serially on the 
Transmit pin and data that is to be received is read in 
from the Receive pin. 


Asynchronous Transmission 


_ The Transmitter Data Output line is held marking (High) 
when the transmitter has no data to send. Under pro- 
gram control, the Send Break command can be issued to 
hold the Data Output line Low (spacing) until the com- 
mand is cleared. 
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The- UART automatically adds the start bit, the program- 
med parity bit (odd, even, or no parity), and the program- 
med -number of stop bits to the data character to be 
transmitted. When the character is five, six, or seven 
bits, the unused most significant bits in the Transmitter 
Data register are automatically ignored by the UART. 


Serial data is shifted from the transmitter at a rate equal 
to 1, 1 /16th, 1 /32nd or 1/64th of the clock rate supplied to 
the transmitter clock input (as determined by the clock 
scale field in the UART Configuration register). Serial 
data is shifted out on the falling edge of the clock input. 


Asynchronous Reception 


An asynchronous receive operation begins when the 
Receive Enable bit in the Receiver Control/Status 
register is set to 1. A Low (spacing) condition on the 
Receive input line indicates a start bit. If this Low per- 
sists for at least one-half of a bit time, the start bit is 
assumed to be valid and the data input is then sampled 
at mid-bit time until the entire character is assembled. 
This method of detecting a start bit improves error rejec- 
tion when noise spikes exist on an otherwise marking 
line. If the x 1 clock mode is selected, bit synchroniza- 
tion must be accomplished externally; received data is 
sampled on the rising edge of the clock. 


A received character can be read from the 8-bit Receiver 
Data register. The receiver inserts 1 s when a character 
length of other than eight bits is used. Ifparity is enabled, 
the parity bit is not stripped from the assembled 
character for character lengths other than eight bits. For 
lengths other than eight bits, the receiver assembles a 
character length of the required number of data bits, 
plus a parity bit and 1 s for any unused bits. 


Since the receiver is buffered by one 8-bit register in ad- 
dition to the receiver shift register, the CPU has enough 
time to service an interrupt and to accept the data 
character assembled by the UART. The receiver also 
has a buffer that stores error flags for each data 
character in the receive buffer. These error flags' are 
loaded at the same time as the data character. 


After a character is received, it is checked for the follow- 
-ing error conditions: 


I!l 
Parity Error: when the parity bit of the character 
does not match the programmed parity. 


c 
Framing Error: if the character is assembled without 
any stop bits (i.e., a Low level is detected for a stop 
bit). 


fJ 
Receiver Overrun Error: if the CPU fails to read a 
data character when more than one character has 
been received. 


The Parity Error, Framing Error, and Receiver Overrun 
Error cause an interrupt request if the interrupt request 
capability is enabled. Since the Parity Error and Receiver 
Overrun Error flags are latched, the error status that is 
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read reflects an error in the current character in the 
Receiver Data register plus any Parity or Overrun Errors 
detected since the last write to the Receiver Con- 
trol/Status register. To keep correspondence between 
the state of the error buffers and the contents of the 
receiver data buffers, the Receiver Control/Status 
register must be read before the data. 


Polled Operation 


In a polled environment, the Receive Character 
Available bit in the Receiver Control/Status register must 
be monitored so the CPU can know when to read a 
character. This bit is automatically cleared when the 


Receiv~r Data register is read. To prevent overwriting 
data in polled operations, the transmitter buffer status 
must be checked before writing into the transmitter. The 
Transmit Buffer Empty bit in the Transmitter Con- 
trol/Status register is set to 1 whenever the transmit buf- 
fer is empty. 


UART Control and Status Registers 


The UART operation is controlled by three control and 
status registers. The UART configuration register 
specifies the character size and parity, the clock source 
and scaling and loop-back enable. Both the transmitter 
. and the receiver have their own control/status register. 


UART Configuration Register. This 8-bit register 
(Figure 24) contains control information for both the 
transmitter and receiver. 
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Figure 24. UART Configuration Register 


The control fields for this register are: 


Loop Back Enable (LB). The UART is capable of local 
loopback. In this mode the internal transmit data line is 
tied to the internal receiver line and the external receiver 
input is ignored. If this bit is set to 1, loop mode is en- 
abled. 


Clock Rate (CR). These two bits specify the multiplier 
between the clock and data rates (00 = data rate x 1, 
01 = data rate x 16, 10 = data rate X 32, 11 = data 
rate X 64). The same rate is used for both the receiver 
and transmitter. If the X 1 clock rate is selected, bit syn- 
chronization must be accomplished externally. 


Clock Select (CS). This bit specifies the clock input for 
, the UART. If the bit is set to 1, the counter/timer 0 output 
pulse is used for bit-rate generation; if the bit is cleared 
to 0, the input line to counter/timer 0 provides the clock 
from an external source. 


Parity Even/Odd (E/O). If parity is specified, this bit deter- 
mines whether it is sent and checked as even or odd (1 
= even). 
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Parity (P). If this bit is set to 1, an additional bit position 
(in addition to those specified in the bits/character con- 
trol field) is added to transmitted data and is expected in 
received data. In the Receiver, the parity bit received is 
transferred to the CPU as a part of the character, unless 
eight bits/character is selected. 


Bits/Character (B/C). Together, these two bits determine 
the number of bits to form a character. If these bits are 
changed during the time that a character is being 
assembled, the results are unpredictable (00 = 5 
bits/character, 01 = 6 bits/character, 10 = 7 bits/ 
character, 11 = 8 bits/character). 


Transmitter Control/Status Register. This 
8-bit 
register (Figure 25) specifies the operation of the 
transmitter. 
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Figure 25. Transmitter Control/Status Register 


The control bits for this register are: 


Transmitter Buffer Empty (BE). This bit is automatically 
set to 1 whenever the transmitter buffer becomes empty, 
and cleared to 0 when a character is loaded into the 
transmit buffer. This bit is in the set condition after a 
reset. This bit is controlled by the UART control circuitry, 
it can be read by an I/O read but cannot be set to 1 or 
cleared to 0 by an I/O write. 


Value (VAL); This bit determines the value of the bits 
transmitted while the FRC bit is 1 and dummy characters 
are loaded into the transmitter buffer. When this bit is 1, 
a mark character (all 1 s) is sent; when this bitis 0, a 
break character (aliOs) is sent. 


Force Character (FRC). When this bit is set to 1, any 
character loaded into the transmitter buffer causes the 
transmitter output to be held High or Lo'v'v' (as indicated 
by the VAL bit) for the length of time required to transmit 
a char)cter; the character itself is not sent until after the 
current character is transmitted. This allows a program 
to generate a marking signal or a break of multiple- 
character duration simply by setting this bit to 1, setting 
the VAL bit to 1 or 0, and loading the appropriate number 
of dummy characters into the transmitter buffer. 


Send Break (BRK). When set to 1, this bit immediately 
forces the transmitter output to the spacing condition, 
regardless of any data being transmitted. When this bit is 
cleared to 0, the transmitter returns to marking. 


Stop Bits (SB). Jhis bit determines the number of stop 
bits added to each asynchronous character sent. The 
receiver always checks for one stop bit. If this bit is set 
to 1, two stop bits are automatically appended to the 
character (and parity) sent; if this bit is cleared to 0, only 
one stop bit is appended. 
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Transmitter Interrupt Enable (IE). When this bit is set to 
1, interrupt requests are generated whenever the 
transmitter buffer becomes empty; when this bit is 
cleared to 0, no requests are made. 


Transmitter Enable (EN). While this bit is cleared to 0, 
data is not transmitted and the transmitter output is held 
marking. Data characters in the process of being 
transmitted are completely sent if this bit is cleared to 0 
after transmission has started. 


Receivor Control/Status Register. This 8-bit register 
(Figure 26) specifies the operation of the receiver. The 
control bits are described below. 
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Figure 26. Recolver Control/Status Register 


Receiver Error (ERR). This bit iS'the logical OR of the PE, 
aVE, and FE bits. 


Framing Error (FE). This bit is automatically set to 1 for 
the received character in which the framing error occur- 
red. Detection of a framing error adds an additional one- 
half of a bit time to the character time so the framing er- 
ror is not interpreted as a new start bit. The bit is latched, 
so once an error occurs it remains set until the bit is 
cleared by software writing to this register. 


Parity Error (PE). When parity is enabled, this bit is 
automatically set to 1 for those characters whose parity 
does not match the programmed sense (even/odd). This 
bit is latched, so once an error occurs, it remains set un- 
til it is cleared by software writing to this register. 


Receiver 'Overrun Error (OVE). This bit is automatically 
set to 1 to indicate that more than two characters have 
been received without a read from the CPU (or. DMA). 
Only the most recently received character is flagged 
with this error, but when this character is read, the error 
condition is latched until cleared by software writing to 
this register. 


,Receiver Character 
Available 
(CA). 
This 
bit 
is 
automatically set to 1 when at least one character is 
available in the receive buffer; it is automatically cleared 
to 0 when the Receiver Data register is read. This bit is 
controlled by the UART control circuitry; it can be read 
by an I/O read but cannot be set or cleared by an I/O 
write. 


Receiver Interrupt Enable (IE). While this bit is set to 1, 
interrupt requests are generated whenever the receiver 
detects an error or the receiver has a character 
available. 


Receiver Enable (EN). When this bit is set to 1, receiver 
operations begin. This bit should be set only after, the 
parameters in the UART Configuration register are set. 
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UART Bootstrapping Option 


The Z800 CPU supports an automatic initialization of 
memory via the UART after a reset operation. This 
system 
bootstrapping 
capability permits 
ROMless 


system configurations: the memory can be initialized by 
a serial link before the Z800 CPU fetches information 
from memory after the reset. 


On the rising 'edge of reset, the AD lines are sensed; if 
AD6 is being driven High, the Z800 CPU automatically 
enters a Halt state. The UART is also automatically ini- 
tialized to receive 8-bit character data with odd parity at 
a X 16 clock rate. An external clock source is assumed. 
A minimum of 15 processor clock cycles must elapse 
before the transmission can begin. 


During the bootstrapping operation, DMA Channel 0 is 
used to transfer received characters into the memory. 
This channel is initialized as follows: 


Transfer Descriptor register-IE, EPS, and "'(C cleared, 
ST-byte transfer, BRP-continuous, TYPE-flowthrough, 
DAD-Auto-increment memorx address 


DMA CHANNELS 


The Z800 MPU has four on-Chip Direct Memory Access 
(DMA) channels to provide high bandwidth data 
transmission capabilities. There are two types of DMA 
channels; two support flyby transactions and the other 
two do not. The two types of DMA channels otherwise 
have identical capabilities, although they have different 
priorities with respect to interrupt requests and bus re- 
quests. 


Each DMA channel is a powerful and versatile device for 
controlling and processing transfers of data. Its basic 
function of managing CPU-independent transfers be- 
tween two ports Is augmented by an array of features re- 
quiring little or no external logic in systems using an 8- or 
16-bit data bus. 


Transfers can be performed between any two ports 
(source and destination), including memory-to-I/O, I/O-to- 
memory, memory-to-memory, and I/O-to-I/O. Except for 
flyby, two port addresses are automatically generated 
for each transaction and can be either fixed or incre- 
menting/decrementing. 


During a transfer, a DMA channel assumes control of 
the system address and data bus. Data is read from one 
addressable port and written to the other addressable 
port, byte-by-byte or word-by-word. The ports can be pro- 
grammed to be either system main memory or 
peripheral I/O devices. 
. 


For both flyby and flowthrough DMA transactions, if the 
destination is a memory location that corresponds to an 
entry in the on-chip memory (either cache or fixed 
memory location), the on-Chip memory is updated to 
reflect the new contents of the memory location. 


DMA Master Control register-DOR and EOP set 


Count register-01 00 (256 bytes to be transferred) 


Destination Address register-OOOOOO (starting memory 
address = 0) 


Source Address register-undefined (not used when 
DMAO is linked to UART) 


Characters received are placed in memory starting at 
physical memory location zero. If an error occurs, the 
Z800 CPU drives the Transmitter Output line Low. Exter- 
nal circuitry monitoring this line can use this Signal to 
cause the transmitting device to begin the initialization 
procedure again, starting with a reset and AD6 asserted 
on the rising edge of RESET. 


After 256 bytes of data have been transferred,the Z800 
CPU automatically begins execution by fetching the first 
instruction from memory location O. 


Except in flyby mode, two 24-bit addresses are 
generated by the DMA for every transfer operation, one 
address for the source port and another for the destina- 
tion port. Two readable address counters (three bytes 
each) keep the current address of each port. 


The DMA devices use the same memory and I/O timing 
as the CPU for bus transactions, as indicated by the ap- 
propriate bus timing register. 


Modes of Transfer Operation 


Each DMA can be programmed to operate in one of 
three transfer modes: 
' 


o 
Single Transaction. Data operations are performed 
one byte or word at a time. 


o 
Burst. Data operations continue until a port's Ready 
line to the DMA goes inactive. 


o 
Continuous. Data operations continue until the end 
of the programmed block of data is reached or if an 
end of process has been signaled before the SYSt(;;:T1 
bus is released. 


In all modes, once a byte or word of data is read by the 
DMA channel, the operation is completed in an orderly 
fashion, regardless of the state of other signals (in- 
cluding a port's Ready line). 


Pin Descriptions 


Each DMA channel has a Ready input line. In addition, 
two DMA channels have a flyby output line to support 
high speed data transfers between I/O devices and 
memory. 
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The flyby output is asserted by the DMA channel to 
signal a peripheral device associated with the DMA 
channel that it should participate in the data transmis- 
sion during the current flyby bus transaction. 


The Ready line is sampled on the rising edge of each pro- 
cessor clock cycle. If Ready is active, the DMA channel 
requests control of the external system bus to perform 
the DMA transaction. When the external system bus is 
available for DMA transfers, the DMA channel with a re- 
quest pending and the highest priority assumes bus 
mastership. The priority of DMA channels from highest 
to lowest is: DMAO, DMA 1, DMA2, and DMA3. A DMA 
channel in burst mode relinquishes bus mastership to a 
higher priority DMA channel only when its Ready line is 
deasserted (or Eap is signaled or terminal count is 
reached). A DMA channel in continuous mode relin- 
quishes bus mastership only when Eap is signaled or 
terminal count is reached. 


Priority of On·Chip DMA Channels and External 
Bus Requesters 


The on-chip DMA channels are arranged in a daisy chain 
with the external Bus Request input line being the "next 
lower bus requester" on this chain. The on-chip DMAs 
behave as if they were external bus requestors with 
respect to acquiring the bus, relinquishing the bus, and 
priority access to the bus. 


End·of·Process 


If the end-of-process (Eap) capability is enabled, 
transfers by DMA channels can be prematurely ter- 
minated by a Low on Interrupt A line during the transfer. 
This capability is programmed by a control bit in the 
DMA Master Control register. Eap occurs regardless of 
the setting of the Interrupt A Enable bit in the Master 
Status register. ,When an Eap is signaled, the EOP 
Signaled (EPS) bit in the Transaction Descriptor register 
of the active DMA channel is set to 1 and the Enable bit 
is cleared to O. If interrupt requests are enabled (IE = 1 
in the Transaction Descriptor register), an interrupt re- 
quest is generated by the channel that was active when 
the Eap was signaled. After an Eap has been Signaled, 
the DMA relinquishes the bus within 16 cycles of the last 
DMA bus transaction. 


If the End-Of-Process signal on Interrupt A line is still 
asserted when the CPU is bus master, the Signal is inter- 
p,reted as an interrupt request; thus both the DMA chan- 
nel and the external EOP generating device can request 
interrupts simultaneously. Separate mask bits in the 
Master Status register enable the CPU to accept inter- 
rupts from these two sources. 


On a flowthrough transaction, if the Eap signal is re- 
ceived while the information is being read into the Z800 
MPU, the transfer is aborted and the data is not written 
out from the Z800 MPU. 
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DMA Linking 


The DMA devices can be linked together to achieve 
DMA transfers to non-contiguous memory locations 
(linked operation). Bits in the DMA Master Control 
register allow DMA3 to be linked to DMA 1 and DMA2 to 
be linked to DMAO, when DMAO and DMA1 have flyby 
capabilities. If the appropriate bit is set to 1 in the DMA 
Master Control register, the master DMA (0 or 1) signals 
its linked DMA each time its transfer is complete (count 
= 0). This acts a? an internal ready input to the linked 
DMA that reloads the master DMA control' registers. 


Words are loaded into the master DMA control registers 
in the following order: Destination Address register (two 
words), Source Address register (two words), Count (one 
word), Transfer Descriptor register (one word). After six 
words have been transferred, the master DMA de- 
asserts its internal ready line and begins the transfer of 
the next block of data. The linked DMA can be program- 
med to interrupt the CPU on "count equal 0" (to notify 
software that the last block is being transferred) or the 
master DMA can be programmed to interrupt the CPU on 
"count equals 0" when the last block move is program- 
med into the master DMA (to notify software that the en- 
tire sequence of transfers is completed). When linking is 
enabled, the external Ready line is not asserted by the 
master DMA when count equals zero; also, both master 
and linked DMAs generate interrupts whenever the pro- 
grammed condition arises. 


When programming linked DMAs, the last word to be 
programmed must be the master DMA's Transaction 
Descriptor register. Also, the linked DMA must be pro- 
grammed before the master DMA's status register is 
programmed. 


DMA Master Control Register. This 16-bit register 
(Figure 27) specifies the general configuration of the four 
on-chip DMA channels: the linking of the DMA channels, 
the software ready enables, edge detection enables for 
the Ready lines, and EOP enable. 


15 


Figure 27_ DMA Master Control Register 


The fields in this register are: 


OMAO to Receiver Link (0 OR). When this bit is set to 1, 
DMA channel 0 is linked to the UART receiver. 


OMA 1 to Transmitter Link (01 T). When this bit is set to 1, 
DMA channel 1 is linked to the UART transmitter. 


OMA2 Link (02L). When this bit is set to 1, DMA channel 
2 is linked to DMA channel O. 
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DMA3 Link (D3L). When this bit is set to 1, DMA channel 
3 is linked to DMA channel 1. 


End-of-Process (EOP). When this bit is set to 1, the INTA 
line is used as an end-of-process signal for the active' 
DMA channel. 


Software Ready for DMAO (SRO). When this bit is set to 1, 
DMA channel 0 requests service if enabled. 


Software Ready for DMA 1 (SR1). When this bit is set to 1, 
DMA channel 1 requests service if enabled. 


Enable Count n (fen). When bit ECn is set to 1, edge 
detection circuitry is enabled on Ready line n. 


DMA Channel Control Registers 


Transaction Descriptor Registers. These four 16-bit 
registers, one for each channel, (Figure 28) describe the 
type of DMA transfer to be performed and contain con- 
trol and status information. 
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Figure 28. Transaction Descriptor Register 


The fields in this register are: 


End-of-Process Signaled (EPS). This bit is set to 1 
automatically when the channel is active and an end-of- 
process is signaled on the Interrupt A input line, thus 
prematurely terminating the transfer. 


Destination Address Descriptor (DAD). The setting of 
this 3-bit field indicates the type of location (memory or 
I/O) and how the address is to be manipulated (in- 
cremented, decremented or left unchanged), as shown 
in Table 4. 


Table 4. SAD and DAD Encodlngs 


Encoding 
Address Modification Operation 


o 0 0 
Auto-increment memory location 
o 0 1 
Auto-decrement memory location 
o 1 0 
Memory address unmodified by transaction 


01 1 
100 
1 01 


Reserved 
Auto-increment (by 1) 1/0 location 
Auto-decrement (by 1) I/O location 
1 1 0 
I/O address unmodified by transaction 
1 1 1 
Reserved 


Transfer Complete (TC). This bit is set to 1 automatically 
when the count register has reached zero. 
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Transaction Type (Type). This 2-bit field specifies flyby or 
flowthrough type of operation or count option (00 = 
flowthrough, 01 = count option, 10 = flyby write, 11 = 
flyby read). In flowthrough mode of operation, two bus 
transactions occur for each DMA operation-a read 
from the source followed by a write to the destination. In 
a flyby operation, only one bus transaction occurs for 
each DMA operation. In flyby write to memory, the flyby 
output pin is pulsed instead of an I/O transaction being 
performed and the contents of the Destination Address 
register are output to specify the memory location. In 
flyby read from memory, the flyby output pin is pulsed in- 
stead of an I/O transaction being performed and the con- 
tents of the Source Address register are output to 
specify the memory location. Only two DMAs have flyby 
capability. In the count option type of operation, the DMA 
acts as a counter and the BRP field governs the counting 
frequency; the "count each" option decrements the 
count register once for each High-to-Low transition on 
the Ready line while the DMA enable bit is set to 1; the 
gate option decrements the count register once for eactl 
eight internal processor clock cycles while the Ready 
line is Low and the DMA enable bit is set to 1. 


Bus Request Protocol (BRP). The setting of these two 
bits indicates the mode of DMA operation (Table 5); their 
interpretation depends on whether the channel is pro- 
grammed for DMA operations or with' the count option. 


Table 5. Bus Request Protocol (BRP) 


Encoding 
DMA 
CounteriTimer 


0 
0 
Single Transaction 
Count each 


0 
1 
Burst 
Gated count 


0 
Continuous 
Continuous gated count 
Reserved 
Reserved 


Size of Transfer (ST). This 2-bit field specifies the size of 
the entity to be transferred by the DMA channel (Table 
6). For word transfers to or from memory locations, the 
memory address must be even (least significant bit is 0). 
Long word (32-bit) transfers are supported only in flyby 
mode, with the cache disabled. 


Table 6. Size of Transaction (S1) 


Encoding 
Size of 
Number to Increment! 


ST1 
STO 
Transfer 
Decrement By 


0 
0 
Byte 


0 
1 
16-bit word 
2 


0 
32-bit longword 
4 
Reserved 
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Interrupt Enab/e (/E). When this bit is set to 1, the DMA 
generates an interrupt request at end of count or end of 
process. When this bit is 0, no interrupt request is 
generated. 


Source Address Descriptor (SAD). The setting of this 
3-bit field indicates the type of location (memory or 110) 
and how the address is to be manipulated (incremented, 
decremented or left unchanged), as shown in Table 4. 


DMA Enab/e (EN). While this bit is 1, the DMA transfer is 
enabled. 


Count Register. This 16-bit register is programmed to 
contain the number of DMA transfers to be performed. 
When the contents of the count register reach zero, fur- 
ther requests on the RDY input line are ignored. The 
DMA channel can be programmed to generate an inter- 
rupt when the count register reaches zero. 


Source Address Register and Destination Address 
Register. These 24-bit registers contain the 24-bit 
physical addresses to be used during the DMA transac- 
tion. They are not translated by the MMU. In flyby mode, 
only one of these registers is used to supply the address 


COUNTER/TIMERS 


The l800 MPU's four counter/timers can be program- 
med by system software for a broad range of counting 
and timing applications. The four independently pro- 
grammable channels satisfy common microcomputer 
system requirements for event counting, interrupt and in- 
terval timing, and general clock generation. 


Three of the four Gounter/timers can have external input; 
the fourth can be used only in the timing mode. 


Programming the counter/timers is straightforward: 
each channel is programmed with four bytes. Once 
started, the channel counts down, and optionally reloads 
its time constant automatically and resumes counting. 
. Software timing loops are completely eliminated. Inter- 


rupt processing is simplified because each channel uses 
,a unique vector from the InterruptlTrap Vector Table. 


Each channel is individually programmed with three 
registers: a configuration byte, a control byte, and a 
time-constant word. The configuration byte selects the 
operating mode (counter or timer), enables or disables 
the channel 
interrupt, and selects certain other 
operating parameters. In the timing mode, the CPU proc- 
essor clock is divided by four for input to the 
counter/timers. The time-constant word contains a value 
from a to 65,535. 


During operation, the individual counter channel counts 
down from the present time-constant value. In counter 
mode operation, the counter decrements on each of the 
input pulses until the count/time output condition is met. 
Each decrement is synchronized by the scaled internal 
processor clock. For counts greater, than 65,536, two of 
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for the bus transaction as indicated in the Mode field in 
the Transfer Descriptor register. The format for these 
registers is shown in Figure 29. 


15 
0 
I 
0 
0 
0 
o I 
A11 • • • • • • • • • • Aol 


15 
0 
I 
A23 • • • • • • • • • • A121 0 
0 
0 
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Figure 29. Source and Destination Address 
Registers Format 


Flyby Transaction Timing 


The Transaction Type field in the Transaction Descriptor 
register indicates whether the transaction is a read or a 
write. For flyby read transactions, the Source Address 
Descriptor indicates the transaction is a read from 
memory; for write flyby transactions the Destination Ad- 
dress Descriptor indicates the transaction is a write to 
memory. Additional wait states can be automatically in- 
serted if programmed in the appropriate timing register. 


the counters can be programmably cascaded. When the 
count/time output condition is reached, the downcounter 
is automatically reset with the time constant value, if so 
programmed. 


The timer mode determines time intervals without addi- 
tional logic or software timing loops. Time intervals are 
generated by dividing the internal processor clock by 
four and decrementing a presettable downcounter. 
Thus, the time interval is an integral multiple of the proc- 
essor clock period, the prescaler value four, and the 
time constant that is preset in the downcounter. A timer 
is triggered by setting the software trigger control bit in 
the Control/Status register or by an external input. 


Three channels can generate an external output when 
the count/time output condition is met. The output is high 
when the internal presettable downcounter contains all 
zeros. 


Each channel can be programmed to generate an Inter- 
rupt Request, which occurs only if the channel has its In- 
terrupt Enable control bit set to 1 by software program- 
ming. When the l800 CPU accepts the interrupt request 
it automatically vectors through the Interrupt Vector 
Table. 


The four channels of the l800 MPU are fully prioritized 
and fit into four different slots in the l800 internal 
peripheral daisy-chain interrupt structure. Channel a has 
the highest priority and Channel 3 has the lowest. The. 
channels have separate interrupt enables and the CPU's 
Master Status register has individual control bits that' 
selectively inhibit interrupts from each channel. 
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Modes of Operation 


Three of the counter/timer channels have two basic 
modes of operation: ,as counters or as timers. As 
counters they monitor external input lines and record 
Low to High transitions on these lines. In the timer mode, 
the processor clock, scaled by.tour, is used instead of 
the external input line. The duration of this counting or 
timing can be either continuous from initial enabling (trig- 
ger operation) or only during intervals specified by 
signals on an input line (gate and gate/trigger operation). 
The count can be automatically 'restarted by program- 
ming 
the 
Retrigger 
Enable 
control 
bit 
in 
the 
counter/timer's Configuration register. Channel number 
2 has no external inputs, and thus operates only as a 
timer. 


Each of the four counter/timers has a software gate and 
trigger facility that extends the hardware capabilities of 
the counter/timers. 


Counting Operation. While the appropriate enabling 
conditions are met, the counter/timer monitors its input, 
line for Low-to-High transitions. When sLich a transition 
occurs, the CountlTime register is decremented by 1. 


Timing Operation. While the appropriate enabling con- 
ditions are met, the counter/timer monitors the internal 
processor clock scaled by four for Low-to-High transi- 
tions. When such a transition occurs the Count/Time 
register is decremented by 1. 


GATE 
INPUT _____ 
_ 


Gate Operation. A counter/timer can be programmed to 
count or time only when a gating condition is met. While 
the counterltimer is enabled and the external gate 
capability is selected, an external input line is monitored; 
only while this line is High are the counting or timing 
operations performed. The software gate facility filters 
the state of the input line; while the software gate bit in 
the Command and Status register is cleared to 0, the 
gating condition is not met regardless of the signals on 
the gating line. The gate facility is illustrated in Figure 30. 


Trigger Operation. A counter/timer can be programmed 
to count or time only after a triggering condition occurs. 
While the counter/timer is enabled and the external trig- 
ger capability is programmed, an external input line is 
monitored; only after this line makes a Low-to-High tran- 
sition is a counting or timing operation performed. The 
software trigger facility causes the triggering condition 
to be met regardless of the activity of this line. The trig- 
ger operation is illustrated in Figu re 31. 


Gate/Trigger Operation. One input line can be used for 
both the gating and the triggering functions. A Low-to- 
High transition on this line acts as a trigger and subse- 
quent High signals on this line function as gate signals. If 
non-retriggerable mode is programmed, subsequent 
Low-to-High transactions do not cause a trigger. 
Gate/Trigger Operation is shown in Figure 32. 


Lfl _____ ......Ir-u-l __ 
COUNTER 
OR TIMER ___ 
... 
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Figure 30_ Gate Facility 


TRIGGER 
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Figure 31. Tr'igger Operation 


* 
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_ __ n __ _ 
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Figure 32. GateITrigger Operation 


The software gate and trigger mechanism can also be 
used in this mode of operation. A software gate before a 
trigger (hardware or software) has no effect on the 
counter/timer. After a hardware or software trigger, the 
software gate must be set to 1 for the Count/Time 
register to be decremented. A software trigger after a 
hardware or software trigger has no effect unless the 
Retrigger Enable control bit is set to 1. 


CounterlTimer Control and Status Registers 


Each counter/timer has two 8-bit control registers and 
two '16-bit count registers. The Configuration register 
and Command and Status register determine the 
counter/timers's operation, the Counter/Timer Com~ 
mand/Status register provides information about the cur- 
rent operation, the Time Constant register contains the 
initialization value for the counter/timer, and the 
Count/Time register contains the current value ot the 
count in progress. 


Counter/Timer Configuration Register. This 8-bit 
register (Figure 33) specifies the counter/timer's mode 
of operation: the pin configuration, whether an interrupt 
request is generated, and whether the countdown se- 
quence is automatically restarted when the count 
reaches zero or when a trigger occurs. 


I CIS I RE liE ICTc·1 
IPA 


'CTC Is present on counter/timers 
o and 2 only. 


Figure 33. CounterlTimer Configuration Register 


The fields in this register are: 


Input Pin Assignments (IPA). This 4-bit field specifies the 
functionality of the input lines associated with the' 
counterltimer and whether the counter/timer monitors 
an external input (counting operation) or uses the scaled 
internal processor clock (timing operation). The four bits 
in this field can be associated with enabling output 
generation (EO), selecting the external signal or internal 
clock (C/T) , enabling the gating facility (G), and enabling 
the triggering facility (T). The selected options determine 
the functions associated with each input line associated 
with the counter/timer, as illustrated in Table 7. 


Counter/Timer Cascade (CTC). When this bit is set to 1, 
counter/timers 0 and 1 and/or counter/timers 2 and 3 
form a 32-bit counter. When used as 32-bit counter/ 
timers, the control and status registers corresponding to 
counter/timers 0 and 2 are not used, with the exception 


Table 7. Input Pin Functionality 


IPA Field 
Pin Functionality 
EO 
CIT 
G 
T 
CounterlTlmer 1/0 
CounterlTlmer Input 
Notes 


0 
0 
0 
0 
Unused 
Unused 
Timer 


0 
0 
0 
1 
Unused 
Trigger 
Timer 


0 
0 
0 
Gate 
Unused 
Timer 


0 
0 
1 
1 
Gate 
Trigger 
Timer 


0 
0 
0 
Unused 
Input 
Counter 


0 
0 
Trigger 
Input 
Counter 


0 
0 
Gate 
Input 
Counter 


0 
1 
1 
1 
GatelTrigger 
Input 
Counter 


0 
O· 
0 
Output 
Unused 
Timer 


0 
0 
1 
Output 
Trigger 
Timer 


0 
0 
Output 
Gate 
Timer 


0 
1 
1 
Output 
GatelTrigger 
Timer 


0 
0 
Output 
Input 
Counter 


0 
1 
Unused 
Unused 
Reserved 


0 
Unused 
Unused 
Reserved 


Unused 
Unused 
Reserved 
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of the CTC bits in the counter/timer configuration 
registers. The CTC bits in the counter/timer configuration 
registers of counter/timers 1 and 3 are never used. 


interrupt Enab/e (IE). While this bit is set to 1 the 
counter/timer generates an interrupt request when the 
count/time output condition is met. While this bit is ° 
no 
interrupt request is generated. 


Retrigger Enab/e (RE). While this bit is set to 1, the time 
constant value 
is 
automatically loaded 
into the 


·Count/Time register when· a trigger input is received 
while the counter/timer is counting down. While this bit is 
0, no reloading occurs. 


Continuous/Single Cycle (C/S). While this bit is set to 1, 
the countdown sequence is automatically restarted . 
when the count reaches zero by loading the time con- 
stant value into the CountlTime register. While this bit is 
0, no reloading occurs. 


Counter/timer channel 2 can be programmed as a 
counter. However, since it has no external inputs to 
count, this is not a useful mode of operation. 


Counter/Timer Command/Status Register. This 8-bit 
register (Figure 34) provides software control over the 
operation of the counter/timer and reflects the current 
status of the counter/timer's operation. Control bits in 
this register enable the counter/timer's operation and 
provide software gate and trigger capabilities. Status 
bits indicate whether a count is in progress, the 
count/time output condition has been reached, or the 
condition has been reached a second time. 


7 
0 
I 
EN I GT I TG I 0 I 0 I CIP I cc ICORI 


Figure 34_ CounteriTimer Command/Status Register 


The fields of this register are: 


Count Overrun (COR). When this bit is set to 1 the 
count/time output condition has been reached and the 
CC bit is set to 1, thus indicating a count overrun condi- 
tion. While this bit is cleared to 0, the count/time output 
condition has not been reached with the CC bit set since 
the time the CC bit was cleared by software. This bit can 
be read or written (set or cleared) by software I/O in- 
structions. 


CounVTime Output Condition has been Met (CC). When 
this bit is set to 1 the CountlTime register has been 
decremented to zero by the counter/timer control cir- 
cuitry in single cycle mode, or the CountlTime register 
has been reloaded in continuous mode. When this bit is 
cleared to ° 
the count has not reached the count/time 
output condition since the bit was cleared by software. 
This bit can be read or written (set or cleared) by soft- 
ware I/O instructions. 


2259-034 


Count in Progress (C/P). While this bit is set to 1 the 
counter/timer is operating and the CountlTime register is 
non-zero; while this bit is cleared to ° 
the counter/timer 
is 
not operating. This 
bit 
is 
controlled by the 
counter/timer control circuitry; it can be read by an 110 
read but cannot be set or cleared by an I/O write instruc- 
tion. 


Software Trigger (TG). When this bit is set to 1. (and the 
trigger operation of the counter/timer is enabled), if the 
Enable bit is also set to.1, the trigger operation is en- 
abled on the rising edge of the first processor clock 
period following the setting of this bit from a previously 
cleared value. That is, if a hardware trigger has not 
already occurred, the contents of the Time Constant 
register are loaded into the CountlTime register and the 
countdown sequence begins. If a hardware trigger has 
already occurred, then if Retrigger Enable is set to 1, the 
counter/timer is retriggered; otherwise, setting this bit 
has no effect. Writing a 1 in this field when the previous 
value was 1 has no effect on the operation of the 
counter/timer. When this bit is cleared to zero, this bit 
has no effect on the operation of the counter/timer. 


Software Gate (GT). When this bit is set to 1 (and the gate 
operation of the counter/timer is enabled), if the Enable 
. bit is also set to 1, operation begins on the rising edge of 
the first processor clock period following the setting of 
this bit from a previously cleared value. Writing a 1 in this 
field when the previous value was 1 has no effect on the 
operation of the counter/timer. When this bit is cleared to 
0, the countdown sequence is halted. 


Enab/e (EN). While this bit is set to 1, the counter/timer is 
enabled; operation begins on the rising edge of the first 
processor clock period following the setting of this bit 
from a previously cleared value. Reset clears this bit. 
While this bit is cleared to 0, the value in the Time Con- 
stant register is. constantly transferred to the Count/Time 
register. If the Time Constant register is all zeros, the 
output of the counter/timer is one. Thus, when the 
counter/timer is not enabled, the counter/timer output in 
conjunction with the Time Constant register can be used 
as an I/O port. Writing a 1 in this field when the previous 
value was 1 has no effect on the operation of the 
counter/timer. While this bit is 0, the counter/timer per- 
forms no operation during the next (and subsequent) 
processor clock periods. 


Time-Constant Register. This 16-bit register holds the 
value that is automatically loaded into the Count/Time 
register when the counter/timer is enabled, or in the con- 
tinuous or retrigger mode when the count reaches zero 
or the trigger is asserted, respectively. This register can 
be read or written by I/O instructions. 


Count/Time Register. This 16-bit register holds the cur- 
rent value of the count or timing in progress. It is auto- 
matically loaded from the Time-Constant register, and 
can be read by software using the I/O read instructions. 
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Pin Descriptions 


Counter/timers 0, 1, and 3 have two external input lines 
associated with them. The I/O lines transfer signals be- 
tween the counter/timers and external devices. The in- 
put lines receive signals from external devices for the 


MULTIPROCESSOR MODE OF 
OPERATION 


Features 


• 
Allows global memory areas for shared resources 


• 
Global memory addresses are user-specified 


• 
Separate requests for local and global buses 


• 
Requesting mechanism is transparent to user 


• 
Easily interfaces to external arbiters 


One mode of operation for the l800 MPU is as an I/O 
Processor (lOP); while in this mode, the l800 MPU also 
supports multiprocessor conf!gurations. While operating 
as an lOP, the l800 MPU is able to support both a local 
bus (of which the l800 MPU is the default bus master) 
and a global bus (for which the l800 MPU must request 
the bus and receive a bus grant signal before issuing a 
bus transaction.) 


To accomplish this functionality, two pins previously 
used for the counter/timer 0 peripheral are dedicated to 
be global bus request and global bus grant lines; thus 
this feature is available only in the 64-pin devices. A 
register in the l800 MPU bus interface unit is accessed 
for each bus transaction to determine whether the 
physical address must be accessed via the global or 
local bus. 


Architecture 


Pin Functionality. Two pins are used by the lOP for ob- 
taining the global bus: the Global Request line is used to 
request the global bus, one which the CPU does not con- 
trol by default (counter/timer 0 input/output), and the 
Global Acknowledge line receives an acknowledge of a 
global bus request (counter/timer 0 input). 


Local Address Register. The bus interface unit 
distinguishes whether a bus transaction uses the local or 
global bus by comparing the four most significant bits of 
the physical address of memory (address bits 20 through 
23) with a 4-bit Base field in the local Address register 
(Figure 35). A mask field in this register specifies which 
bits are to be used. If all the corresponding address bits 
match the Base field bits (for those bit positions 
specified by the mask field), then the bus transaction can 
proceed on the local bus without requesting the global 
bus; if there is a mismatch in at least one specified bit 
position, then the global bus is be requested and the bus 
transaction does not proceed until the global bus 
acknowledge Signal is asserted. 
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counter/timers. The interpretations of the signals on 
these lines is determined by the Input Pin Assignment 
field in the Configuration register. 
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Figure 35. Local Address Register 


The bits in the local Address register are: 


Base (Bn). When Bn is 1, address bit An must be 1 for a 
local bus transaction to be performed (unless Match 
Enable bit MEn is 0); when bit Bn is 0, address bit An must 
be 0 for a local bus transaction to be performed. 


Match Enable (MEn). When MEn is 1, address bit An is 
compared to base bit Bn to determine if the address re- 
quires the use of the global bus. When MEn is 0, then any 
values for An and Bn will produce a match. If each MEn is 
. 0, then all bus transactions are performed on the local 
bus. 


CPU Accesses on the Global Bus 


The control of the local bus uses BUSREQ and BUSACK 
in the same way as in the non~multiprocessor mode of 
operation. The input Signal BUSREQ is. asynchronous to 
the processor clock; the CPU synchronizes BUSREQ in- 
ternally. When the CPU acknowledges a local bus re- 
quest by driving BUSACK active, then the CPU places all 
other output signals, including GREQ, in 3-state. After 
reset the CPU acknowledges a request for the local bus 
before performing any transactions. 


When the CPU has not granted the local bus then it can 
request a global bus. A timing diagram for global bus re- 
quest is shown in Figure 36. First, on a rising edge of 
ClK, the CPU drives the address and status lines valid. 
AS is not asserted, however; GREQ serves the function 
of indicating that a valid address is on the local bus. On 
the next falling edge of ClK the CPU drives GREQ active. 
The CPU samples GACK on each falling edge of ClK un- 
til the arbiter drives GACK active and leaves BUSREQ in- 
active, indicating that the addressed global bus is 
available to tne CPU. The BUSREQline is used by the ar- 
biter to remove all of the devices that are simultaneously 
requesting the global bus, except the one device that is 
granted the global bus. The devices that are not granted 
the global bus make their GREQ inactive. The input 
Signal GACK is asynchronous to the processor clock; the 
CPU synchronizes GACK internally. The CPU that was 
granted the bus performs one or more transactions on 
the global bus until the CPU no longer needs the global 
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bus or the CPU is prepared to acknowledge a local bus 
request. The CPU then drives GREQ inactive and wa~ts 
for the arbiter to drive GACK inactive. The CPU relIn- 
quishes the global bus upon receipt of a local bus, DMA, 
or refresh request or after any transaction except for a 
test and set instruction (both data read and write are per- 
formed before relinquishing the bus) and for burst 
transfers (the entire sequence of data reads are made). 


DMA Accesses on the Global Bus 


Each on-chip DMA device can use the global bus to per- 
form data transfers. The address generated during each 
DMA initiated transfer is compared with the contents of 
the Local Address register to determine whether the 
global bus is requested; this operation is the same as for 
CPU-generated requests. 
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Figure 36. Multiprocessor Mode Timing 


EXTERNAL INTERFACE (ZaO·BUS) 


Features 


Ell 
8-bit data bus 


a 
Multiplexed address/data lines 


EJ 
Supports Z80 Family peripherals 


Pin Descriptions 


A. Address (output, active High, 3-state). These address 
lines carry I/O addresses and memory addresses during 
bus transactions. Of the 16 lines, only 11 are available 
on the 40-pin version. 


AD. A"ddresslData (bidirectional, active High, 3-state). 
These eight multiplexed Data and Address lines carry I/O 
addresses, memory addresses, and data during bus 
transactions. 


AS. Address Strobe (output, active Low, 3-state). The ris- 
ing edge of AS indicates the beginning of a transaction 
and shows that the address is valid. 


2259·036 


BUSACK. Bus Acknowledge (output, active LOW). A Low 
on this line indicates that the CPU has relinquished con- 
trol of the bus in response to a bus request. 


BUSREQ. Bus Request(input, active LOW}. A Low on this 
line indicates that an external bus requester has ob- 
tained or is trying to obtain control of the bus. 


ClK. Clock Output (output). The frequency of the proc- 
essor timing clock is derived from the oscillator input 
(external oscillator) or crystal frequency (internal 
oscillator) by dividing the crystal or external oscillator in- 
put by two. This clock is further divided by one, two, or 
four (as programmed), and then output on this line. 


HALT. Halt (output, active Low, 3-state). This Signal in- 
dicates that the CPU has executed a Halt instruction and 
is awaiting an interrupt before operation can resume. 


INT. Maskable Interrupts (input, active Low). A Low on 
one is available on the 40-pin version. 
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lORa. InpuVOutput Request (output, active Low, 
3-state). This signal indicates that ADo-AD7 and A16-A23 
of the address bus hold a valid 1/0 address for a 1/0 read 
or write operation. An 10RO signal is also generated with 
an M1 signal when an interrupt is being acknowledged, 
to indicate that an interrupt response vector can be 
placed on the data bus. Interrupt acknowledge opera- 
tions occur during M1 time and 1/0 operations never oc- 
cur during M1 time. 


M1. Machine Cycle One (output, active Low, 3-state). 
This signal indicates that the current transaction is the 
opcode fetch cycle of a RETI instruction execution. M1 
also occurs with 
lORa to indicate an 
interrupt 


acknowledge cycle. 


MREa. Memory Request (output, active Low, 3-state). 
This signal indicates that the address bus holds a valid 
address for a memory read or write operation. 


NMI. Nonmaskable Interrupt (input, falling-edge ac- 
tivated). A High-to-Low transition on this line requests a 
nonmaskable interrupt. 


RD. Read (output, active Low, 3-state). This signal in- 
dicates that the CPU or DMA peripheral is reading data 
from memory 9r an 1/0 device. 


RESET. Reset (input, active LOw). A Low on this line 
resets the CPU and on-chip peripherals. 


RFSH. Refresh (output, active Low, 3-state). This signal 
indicates that the lower ten bits of the Address bus con- 
tain a refresh address for dynamic memories and the 
current MREO signal should be used to perform a 
refresh read to all dynamic memories. 


WAIT. Wait (input, active LOw). A Low on this line in- 
dicates that the responding device needs more time to 
complete a transaction. 


WR. Write (output, active Low, 3-state). This signal in- 
dicates that the bus holds valid data to be stored at the 
addressed memory or I/O location. 


>.<TALI. Clock/Crystal Input (time-base input). Connects 
a series-resonant crystal or an external single phase 
clock to the on-chip oscillator. 


XTALO. Crystal Output (time-base output). Connects a 
series-resonant crystal to the on-chip oscillator. 
+ 5 V. Power Supply Voltage. (+ 5 nominal). 


GNO. Ground. Ground reference. 


The following lines are available only on the 64-pin ver- 
sion: 


OMASTB. DMA Flyby Strobe (output, active Low). These 
lines select peripheral devices for flyby transfers. 


CTIN. Counter/Timer Input (input, active High). These 
lines receive signals from external devices for the 
counter/timers. 
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CTIO. Counter/Timer I/O (bidirectional, active High, 
3-state). These I/O lines transfer signals between the 
counter/timers and external devices. 


IE. Input Enable (output, active Low, 3-state). A Low on 
this line indicates that the direction of transfer on the Ad- 
dress/Data lines is toward the CPU. 


OE. Output Enable (output, active Low, 3-state). A Low 
on this line indicates that the direction of transfer on the 
Address/Data lines is away from the CPU. 


PAUSE. CPU Pause (input, active Low, Z8216 only). 
While this line is Low the CPU refrains from transferring 
data to or from on Extended Processing Unit in the 
system or from beginning the execution of an instruc- 
tion. 


RX. UART Receive (input, active High). This line receives 
serial data at standard TIL levels. 


ROY. DMA Ready (input, active Low). These lines are 
monitored by the DMAs to determine when a peripheral 
device associated with a DMA port is ready for a read or 
write operation. When a DMA port is enabled to operate, 
its Ready line indirectly controls DMA activity; the man- 
ner in which DMA activity is controlled by the line varies 
with the operating mode (single-transaction, burst, or 
continuous). 


TX. UART Transmit (output, active High). This line 
transmits serial data at standard TIL levels. 


Bus Operations 


Two kinds of operations can occur on the system bus: 
transactions and requests. At any given time, one device 
(either the CPU or a bus requester) has control of the bus 
and is known as the bus master. A transaction is initiated 
by the bus master and is responded to by some other 
device on the bus. Only one transaction can proceed at a 
time; eight kinds of transactions can occur: 


DMA Flyby. This transaction is used by the DMA 
peripheral to transfer data between an 
external 
peripheral and memory. 


Halt. This transaction is used to indicate that the CPU is 
executing a halt instruction. 


Internal Operation. This type of transaction does not 
transfer data; it indicates that the CPU is performing an 
operation that does not require data to be transferred on 
the bus. 


Interrupt Acknowledge. This transaction is used by the 
CPU to acknowledge an interrupt and to transfer addi- 
tional information from the interrupting device. 


I/O. This transaction is used by the CPU or DMA 
peripheral to transfer data to or from an external 
peripheral. 


Memory. This transaction is used by the CPU or DMA 
peripheral to transfer data to or from a memory location. 


Refresh. This type of transaction performed by the 
refresh peripheral does not transfer data; it refreshes 
. dynamic memory. 


RET!. This transaction is generated only by the CPU and 
is used in conjunction with the Z8400 peripheral's inter- 
rupt logic. 


Only the bus master can initiate transactions. A request, 
however, can be initiated by a component that does not 
have control of the bus. Two types of these requests can 
occur: 


Bus. This request is used by external devices to request 
control of the system bus to initiate transactions. 


Interrupt. This request is used to request the attention of 
the CPU. 


When an interrupt or bus request is made, it is answered 
by the CPU according to its type. For an interrupt re- 
quest, the CPU initiates an interrupt acknowledge trans- 
action and for bus requests, the CPU enters bus discon- 
nect state, relinquishes the bus, and activates an 
Acknowledge signal. 


Finally, the Z800 MPU itself may not be the system bus 
master. See the multiprocessor mode section for a 
discussion of this capability. 


Transactions 


Information transfers (both instructions and data) to and 
from the Z800 MPU are accomplished through the use of 
transactions. All transactions start when AS is being 
driven low and then rqised High. This Signal can be used 
to latch Z800 MPU addresses to de-multiplex the Z800 
Address/Data lines required by Z80 Family peripherals. 
Coincident with AS assertion, the Output Enable line is 
also asserted. 


If the transaction requires an address, it is valid on the 
rising edge of AS. No address is required for Interrupt 
Acknowledge. 


The Read and Write lines are used to time the actual 
data transfer. (Refresh transactions do not transfer any 
data and thus do not activate RD.) For write operations, 
a low on WR indicates that valid data from the bus 
master is on the AD lines. The Output Enable line is also 
activated with WR. For read operations, the bus master 
makes the AD lines 3-state before driving RD low so that 
the addressed device can put its data on the bus. The 
bus master samples this data on the falling clock edge 
just before raising RD High. The Input Enable line is also 
activated with RD. 


Wait. The Wait line is sampled on the falling clock edge 
when data is to be sampled (i.e. when RD or WR rises). If 
the Wait line is low, another cycle is added to the trans- 
action before data is sampled (RD or WR rises). In this 
added cycle, and all subsequent cycles added due to 
WAIT being low, the Wait line is sampled on the falling 


edge and, if it is low, another cycle is added to the trans- 
action. In this way, the transaction can be extended by 
external devices to an arbitrary length to accommodate 
(for example) slow memories or 1/0 devices that are not 
yet ready for data transfer. 


The WAIT input is synchronous, and must thus meet the 
specified setup and hold times in order for the Z800 MPU 
to function correctly. ThiS requires asynchronously- 
generated WAIT signals to be synchronized to the ClK 
output before they are input into the Z800 MPU. 
Automatic wait states can also be generated by pro- 
gramming the Bus Timing and Control register.and Bus 
Timing and Initialization register; these are inserted in 
the transaction before an external WAIT signal is sam- 
pled. 


Memory Transactions. Memory transactions move in- 
structions or data to or from memory when the Z800 
MPU makes a memory access. Thus, they are generated 
during program execution to fetch instructions from 
memory and to fetch and store memory data. They are 
also generated to store old program status and fetch 
new program status during interrupt and trap handling, 
and are used by DMA peripherals to transfer informa- 
tion. A memory transaction is three bus cycles long 
unless extended with wait states, as explained pre- 
viously. 


During the first bus cycle, AS is asserted to indicate the 
beginning of a transaction. The MREQ signal goes active 
during the second half of this bus cycle, which indicates 
a memory transaction. For a Read operation (Figure 37), 
RD is activated during the first half of the second bus cy- 
cle; Output Enable is deasserted at the beginning of the 
second cycle and Input Enable is asserted during the se- 
cond half of the second cycle. The CPU samples infor- 
mation from the memory on the Address/Data bus with 
the falling edge of the clock during the third bus cycle 
and this same edge is used to deassert MREQ, and iE. 
Thus the data has already been sampled before RD is 
deasserted. For a Write operation (Figure 38) the WR line 
is asserted during the second half of the second cycle .. 


RETI Transactions. These transactions (Figure 39) are 
similar to two memory read transactions except that M 1 
is asserted throughout each read transaction, falling ear- 
ly in the first bus cycle, and that MREQ, M1, RD and iE 
are deasserted on the riSing edge of the clock following 
the third cycle. Each of the read transactions is followed 
by a minimum of three bus cycles of inactivity. These 
transactions are invoked when an RETI instruction·is en- 
countered in the instruction stream; they are used during 


. the re-fetching of the instruction from memory so that in- 


terrupt logic within Z80 peripherals that monitor the bus 
for this instruction will function correctly. 
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Figure 37. Memory Read Timing 
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Figure 38. Memory Write Timing 
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Figure 39. RETI Read Timing 
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Internal Operations and Halt Transactions. There are 
two kinds of bus transactions that do not transfer data: 
Internal Operations (Figure 40) and Halt (Figure 41). Both 
transactions look like a memory transaction, except that 
RD and WR remain High and no data is transferred. For 
the Internal Operation transaction, 
MREQ is not 
asserted. The Wait line is not sampled during either the 
Internal Operation or Halt transactions. 


Halt transactions are identical to memory read transac- 
tions except that HALT is asserted throughout the trans- 
action, falling during the second half of the first bus 
cycle, and remains asserted until an interrupt is 
acknowledged. This transaction is invoked when a Halt 
instruction is encountered in the instruction stream or a 
fatal sequence of traps occurs. Although the Halt trans- 
action is three cycles, the HALT line remains asserted 
until an Interrupt request is acknowledged or a Reset is 
received. Refresh (to maintain a minimum frequency of 
bus transactions) or DMA transfers may occur while 
HALT is asserted; also, the bus can be granted. The ad- 
dress put out during the address phase of this cycle is 
the address of the Halt instruction. 


I/O Transactions. 1/0 transactions move data to (Figure 
42) or from (Figure 43) peripherals and are generated 
during the execution of 1/0 instructions. 


1/0 transactions are four clock cycles, long at a 
minimum, and may be lengthened by the addition of wait 
cycles. The extra clock cycle allows for slower 
peripheral operation. 


The 10RO line indicates that an 1/0 transaction is taking 
place. The I/O address is found on ADo-AD? and Aa-A23 
when AS rises. 


The 10RO line and either RD and iE or WR with OE still 
asserted, are asserted during the second cycle. Output 
data to the peripheral is placed on the bus at this time; in- 
put data from the peripheral is read during the fourth 
cycle (unless additional wait states are inserted in the 
transaction). 
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Figure 40; Internal Operation Timing 


640 
2259'{)4O 


2259'()41, 042 


I_Tl-I-T2-I-T3-1 
.J 
I 


ACo-AC7 


As-Am 
ADDRESS· 


HIGH 


AD At.C wit 
HIGH 


ACo-AC7 


As-Am 


AS 


wit 


OE* 


IE· 


OE** 


IE ** 


Figure 41. Halt Timing 
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Figure 42. 1/0 Write Timing 
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Figure 43. 110 Read Timing 


Interrupt Acknowledge Transactions. These transac- 
tions (Figure 44) acknowledge an interrupt or trap and 
read information from the device that generated the in- 
terrupt. The transactions are generated automatically by 
the hardware when an interrupt request is detected. 


The Interrupt Acknowledge transactions are five cycles 
long at a minimum, and have two automatic Wait cycles. 
The wait cycles are used to give the interrupt priority 
daisy chain (or other priority resolution device) time to 
settle before the identifier is read. Additional automatic 
wait states can be generated by programming the Bus 
Timing and Control register. 


The interrupt acknowledge transaction is indicated by an 
M1 assertion without MREO during the first cycle. During 
this transaction the IORO signal becomes active during 
the third cycle to indicate that the interrupting device 
can place an 8-bit vector on the bus. It is captured from 
the AD lines on the falling clock edge just before IORO is 
raised High. 
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There are two places where the WAIT line is sampled 
and, thus, where await cycle can be inserted by external 
circuitry. The first serves to delay the falling edge of 
IORO to altow the daisy chain a longer time to settle, and 
the second serves to delay the pOint at which the vector 
is read. 
. 


Refresh Transactions. A memory refresh transaction 
(Figure 45) is generated by the Z8aa refresh mechanism 
and can occur immediately after the final ,clock cycle of 
any other transaction. The memory refresh counter's 
1 a-bit address is output on ADo-ADg during the normal 
time for addresses. The RFSH line is activated with 
MREO. This transaction can be used to generate 
refreshes for dynamic RAMs. 


2:259-{)43 


j.--TLAST--... 
·+I· 
.. ---T1-!_T2-I...--TW-I-Tw-!_T3-1 
..J 
I 
I 
I 
I 
I 


/ 


---( 


ADO-AD7 
UNDEFINED* ." 
/ 


As-Am 


/ 


OE** 
\ 


IE* * 


* AD1 and AD2 indicate type of interrupt being acknowledged. 
* * Z8208 only. 


m = 18 for Z8108, 23 for Z8208. 


I 
I 


UNDEFINED 


HIGH 


\ 


HIGH 


Figure 44. Maskable Interrupt Acknowledge Sequence 
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Figure 45. Refresh Timing 


Requests 


There are three kinds of request signals that the l800 
MPU supports. These are: 


• 
Interrupt requests, which another device initiates 
and the CPU accepts and acknowledges. 


• 
Bus requests, which an external potential bus 
master initiates and the l800 MPU accepts and 
ackno'vvledges. 
\ 


• 
Global bus requests, which the CPU or on-chip DMA 
initiates to acquire a global System bus. 


When a request is made, it is answered according to its 
type: for interrupt requests, an Interrupt Acknowledge 
transaction is initiated; for bus requests, an 
Acknowledge signal is sent; for global bus requests, an 
Acknowledge signal is received. 


Interrupt Requests. The l800 CPU supports two types 
of interrupt, maskable and nonmaskable (NMI). The In- 
terrupt Request line of a device that is capable of 
generating an interrupt can be tied to the NMI or 
maskable interrupt request lines. Several devices can be 
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connected to one pin with the devices arranged in a 
priority daisy chain. However, all l80 family peripherals 
should be on the same line (or no nesting of interrupts 
among different lines. The CPU uses different protocols 
for handling requests on the NMI pin than the protocol 
used for maska~le interrupt pins. The sequence of 
events shown below should be followed: 


Any High-to-Low transition on the NMI input is asyn- 
chronously edge-detected, and the internal NMI latch is 
set. At the beginning of the last clock cycle in the last in- 
ternal processor clock cycle of any instruction, the inter- 
rupt inputs are sampled along with the state of the inter- 
nal NMI latch. 


If a maskable interrupt is requested and the Master 
Status register indicates that requests on that line are to 
be accepted, the next possible bus transaction is the In- 
terrupt Acknowledge transaction, which results in infor- , 
mation from the highest-priority interrupting device be- 
ing read off the AD lines. This data is used to initiate the 
interrupt service routine. For a nonmaskable interrupt re- 
quest, the hexadecimal constant 0066 is used to initiate. 
the interrupt service routine, except in mode 3. 
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Bus Requests. To generate transactions on the bus, a 
potential bus master (such as the DMA Controller) must 
gain control of the bus by making a bus request. A bus 
request is initiated by pulling BUSREO Low. Several bus 
requesters may be wire ORed to the BUSREO pin; 
priorities are resolved externally to the CPU, usually by a 
priority daisy chain. 


The asynchronous BUSREO signal generates an internal 
BUSREO, which is synchronous. If the external' BUSREO 
is Low at the beginning of any machine cycle, the inter- 
nal 
BUSREO 
causes 
the 
Bus Acknowledge line 


(BUSACK) to be asserted after the current machine cy- 


EXTERNAL INTERFACE (Z·BUS) 


Features 


[] 
16-bit data bus 


IJ 
Multiplexed address/data lines 


IJ 
Supports high-speed burst mode transfers 


D 
Provides EPA interface 


Pin Descriptions 


A. Address (output, active High, 3-state). These address 
lines carry I/O addresses and memory addresses during 
bus transactions. Of the eight lines, only three are 
available on the 40-pin version. 


AD. Address/Data (bidirectional, active High, 3-State). 
These 16 multiplexed address and data lines carry I/O 
addresses, memory addresses, and data during bus 
transactiqns. 


AS. Address Strobe (output, active Low, 3-state). The ris- 
ing edge of Address Strobe indicates the beginning of a 
transaction and shows that the address, status, R/Wand 
B/W signals are valid. 


BUSACK. Bus Acknowledge (output, active Low). A Low 
on this line indicates that the CPU has relinquished con- 
trol of the bus in response to a bus request. 


BUSREQ. Bus Request (input, active Low). A Low on this 
line indicates that an external bus requester has ob- 
tained or is trying to obtain control of the bus. 


B/W. Byte/Word (output, Low = Word, 3-state). This 
signal indicates whether a byte or a word of data is to be 
transmitted during a transaction. 


ClK. Clock Output (output). The frequency of the proc- 
essor timing clock is derived from the oscillator input 
(external oscillator) or crystal. frequency (internal 
oscillator) by dividing the crystal or external oscillator in- 
put by two. This clock is further divided by one, two or 
four (as programmed), and then output on this line. 


OS. Data Strobe (output, active Low, 3-state). This signal 
provides timing for data movement to or from the bus 
master. 


cle is completed. (Exceptions are the TSET instruction 
where· the read-modify-write cycle is atomic and DMA 
transfer in burst or continuous mode). The CPU then 
-enters Bus Disconnect state and gives up control of the 
bus. All CPU Output pins, except BUSACK, are 3-stated. 


The CPU regains control of the bus after BUSREO rises. 
Any device desiring control of the bus must wait at least 
two bus cycles after BUSREO has risen before pulling it 
down again. 


The on-Chip DMA channels have higher priority than ex- 
ternal devices requesting the bus via BUSREO. 


INT. Maskable Interrupts (input, active LOW). A Low on 
these lines requests an interrupt. Of the three lines, only 
one is available on the 40-pin version. 


NMI. 'Nonmaskable Interrupt (input, falling-edge ac- 
tivated). A High-to Low transition on this line requests a 
Nonmaskable Interrupt. 


RESET. Reset (input, active Low). A Low on this line 
resets the CPU. 


R/W. Read/Write (output, Low = Write, 3-state). This 
Signal determines the direction of data transfer for 
memory, 110, or EPU transfer transactions. 


ST. Status (output, active High, 3-state). These four lines 
indicate the type of transaction occuring on the bus and 
give additional information about the transaction. 


WAIT. Wait (input, active Low). A Low on this line in- 
dicates that the responding device needs more time to 
complete a transaction. 


_ XTALI. Clock/Crystal Input (time-base input). Connects 
a series-resonant crystal or an external Single-phase 
clock to the on-chip clock oscillator. 


XTAlO. Crystal Output (time-base output). Connects a 
series-resonant crystal to the on-chip clock oscillator. 
+ 5 V. pOv~'pr Supply Voltage. (+ 5 nominal). 


GND. Ground. Ground reference. 


The following lines are available on the 64-pin device 
version only: 


DMASTB. DMA Flyby Strobe (output, active Low). These 
lines select peripheral devices for DMA flyby transfers. 


CTIN. Counter/Timer Input (input, active High). These 
lines receive Signals from external devices for the 


. counter-timers. 


CTIO. Counter/Timer I/O (bidirectional, active High, 
3-state). These 110 lines transfer signals between the 
counterltimers and external devices. 
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IE. Input Enable (output, active Low, 3-state). A Low on 
this line indicates that the direction of transfer on the Ad- 
dress/Data lines is toward the CPU. 


OE. Output Enable (output, active Low, 3-state). A Low 
on this line indicates that the direction of transfer on the 
AddresslData lines is away from the MPU. 


PAUSE. CPU Pause (input, active Low, Z8216 only). 
While this line is Low the CPU refrains from transferring 
data to or from an Extended Processing Unit in the 
system or from beginning the execution of an instruc- 
tion. 


RX. UART Receive (input, active High). This line receives 
serial data at standard TTL levels. 


ROY. DMA Ready (input, active Low). These lines are 
monitored by the DMA channels to determine when a 
peripheral device associated with a DMA channel is 
ready for a read or write operation. When a DMA chan- 
nel is enabled to operate, its Ready line indirectly con- 
trols DMA activity; the manner in which DMA activity is 
controlled by the line varies with the operating mode 
(single-transaction, burst or continuous). 


TX. UART Transmit (output, active High). This line 
transmits serial data at standard TTL levels. 


Bus Operations 


Two kinds of operations can occur on the system bus: 
transactions and request. At any given time, one device 
(either the CPU or a bus requester) has control of the bus 
and is known as the bus master. A transaction is initiated 
by the bus master and is responded to by some other 
device on the bus. Only one transaction can proceed at a 
time; nine kinds of transactions can occur: 


Burst Memory. These transactions are used to transfer 
four words of instructions from the memory to the CPU. 


DMA Flyby. This transaction is used by the DMA 
peripheral to transfer data between an 
external 
peripheral and memory. 


EPU Transfer. This transaction is used to transfer data 
between the CPU and an EPU. 


Halt. This transaction is used to indicate that the CPU is 
executing the Halt instruction. 


Internal Operation. These transactions do not transfer 
data. 


Interrupt Acknowledge. This transaction is used by the 
CPU to acknowledge an external interrupt request and to 
transfer additional information from the interrupting 
device. 
' 


liD. This transaction is used by the bus master to 
transfer data to or from an external peripheral. 


Memory. This transaction is used by the bus master to 
transfer data to or from a memory location. 


Refresh. These transactions by the refresh mechanism 
do not transfer data; they refresh dynamic memory. 
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Only the bus master can initiate transactions. A request, 
however, can be initiated by a device that does not have 
control of the bus. Two types of requests can occur: 


Bus. -This request is used to request control of the bus to 
initiate transactions. 


Interrupt. This request is used to request the servicing by 
the CPU. 


When an interrupt or bus request is made, it is answered 
according to its type: for an externally generated inter- 
rupt request, an Interrupt Acknowledge transaction is in- 
itiated by the CPU; for bus requests, the MPU enters Bus 
Disconnect state, relinquishes the bus, and activates an 
acknowledge signal. 


Transactions 


Data transfers to and from the Z800 MPU are ac- 


, complished through the use of transactions. 


All transactions start with Address Strobe (AS) being 
driven Low and then raised High by the Z800 MPU. On 
the rising edge of AS, the Status lines STo-ST3 are valid; 
these lines indicate the type of transaction being in- 
itiated (Table 8); seven types of transactions are discuss- 
ed in the sections that follow. Associated with the status 
lines are two other lines that become valid at this time: 
RIW, and BIW. 


Table 8. Status Table 


Code 
Meaning 


0000 
Internal operation 


0001 
Refresh 


0010 
110 transaction ' 


0011 
Halt 
0100 
Interrupt acknowledge line A 


0101 
Interrupt acknowledge (nonmaskable) 


0110 
Interrupt acknowledge line B 


0111 
Interrupt acknowledge line C 
1000 
Memory Reference (cachable) 


1001 
Memory Reference (non-cachable) 


1010 
Memory-EPU transfer 


1011 
Reserved 


1100 
EPU Instruction fetch 


1101 
EPU Instruction fetch (first word) 


1110 
EPU-CPU transfer 
1111 
Test and Set (data transfers) 


If the transaction requires an address, it is valid on the 
rising edge of AS. No address is required for EPU-CPU 
transfer and Internal Operation transactions; the con- 
tents of the A and AD lines while AS is asserted are 
undefined. If an address is generated, the OE signal is 
also activated. 


The Z-BUS MPUs use Data Strobe (DS) to time the actual 
data transfer. (Note that Refresh, Halt, and Internal 
Operation transactions do not transfer any data and thus 
do not activate DS.) For write operations (R/W = Low), a 
Low on OS indicates that valid data from the bus master 
is on the AD lines. The Output Enable continues to be 
asserted until DS is deasserted. For read operations 
(RIW = High), the bus master makes AD Lines 3-state, 
deasserts'OE and asserts IE after driving DS Low so that 
the addressed device can put its data on the bus. The 
bus master samples this data on the falling clock edge 
just before raiSing DS and IE High. 


Walt. The Wait line is sampled on the falling clock edge 
when data is sampled by the Z800 MPU (Read), or the 
falling clock edge before DS rises (Read or Write). If 
WAIT is Low, another cycle is added to the transaction 
before data is sampled or DS rises. In this added cycle, 
and all subsequent cycles added when WAIT is Low, 
WAIT is again sampled on the falling clock edge and, if it 
is Low, another cycle is added to the transaction. In this 
way, the transaction can be extended to an arbitrary 
length by external circuitry to accommodate (for exam- 
ple) slow memories or I/O devices that are not yet ready 
for data transfer. Automatic insertions of wait states by 
the CPU or on-chip DMA channels can be programmed 
by setting fields in the Bus Timing and Control register 
and Bus Timing and Initialization register to indicate the 
number to be inserted. 


Memory Transactions. Memory transactions move 
data to or from memory when a bus master makes a 
memory access. Thus, they are generated during pro- 
gram execution to fetch instructions from memory and 
to fetch and store memory data. They are also generated - 
to store old program status and fetch new program 
status during interrupt and trap handling and after reset. 


A memory transaction is three bus cycles long unless ex-' 
tended when WAIT is asserted, as explained above in the 
Wait section. The status pins, besides indicating a 
memory transaction, give the following information: 


• 
Whether the memory access is cacheable (1000) or 
noncacheable (1001) information. 


II Whether the data for the access is supplied (written) 
or captured (read) by an Extended Processing Unit 
(1010). 


[3 
Whether the information being fetched from memory 
is an EPA template (1100, 1101). 


II Whether the memory access is part of the read- 
modify-write operation (Test and Set) (1111). 


Bytes transferred to or from odd memory (address bit a 
is 1) locations are always transmitted on lines ADo-AD? 
(bit a on ADo). Bytes transferred to or from even memory 
locations (address bit 0 = 0) are always transmitted on 
lines ADa-AD15 (bit a on ADa). For byte reads (BIW High, 
RIW High), the CPU or on-chip DMA channel uses only 
the byte whose address it put out on the bus. For byte 
writes (BIW High, R/W Low), the memory should store 
only the byte whose address was output. During byte 
memory writes, the cf:>u (or on-chip DMA channel in non- 
Flyby transactions) places the same byte on both halves 
of the bus, and the proper byte must be selected by 
testing Ao. For word transfers, (R/W = Low), all 16 bits 
are captured by the CPU or DMA channel (Read: RIW = 
High) or stored by the memory (Write: RIW = Low). For 
these transactions (either memory or I/O) the bytes of 
data appear swapped on the bus with the most signifi- 
cant byte on ADrADo and the least significant byte on 
AD15-ADa· 


Memory transaction timings are shown in Figures 46-50. 
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Figure 46. Memory Read Timing 
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Figure 47. Memory Write Timing 
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Figure 50. Memory Read Timing with Internal Wait Cycle 


Burst Memory Transactions. Burst memory transac· 
tions use multiple Data Strobes associated with a single 
Address Strobe. The CPU uses burst transactions to 
read four consecutive words in four data transactions~ 
The address of the first word read during a burst transac- 
tion has zeros in the three least significant bits. Control 
bits in the Cache Control register indicate whether or not 
portions of-the memory system can support burst trans- 
actions. 


The CPU uses burst mode reads only for fetching in- 
structions. If an instruction is to be fetched from a loca- 
tion within a half of physical memory that supports burst 
transactions, the CPU reads the eight bytes that contain 
the first byte of the instruction. (EPA template fetches 
and the RETI 
instruction do not use the burst 
transaction.) 


Timing for the first data transfer during a burst transac- 
tion is identical to that for a single memory read, in- 
cluding the automatic insertion of wait states, except 
there are four T3 states. Subsequent data transfers do 
not include automatic wait states. On the first data 
transfer, if WAIT is sampled active then it is sampled 
again every bus clock cycle until it is inactive, at which 
time the data is read from the bus. Burst memory read 
timing is shown in Figure 51, 
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Internal Operation and Halt Transactions. Two types 
of bus transactions made by the CPU do not transfer 
data: Internal Operations and Halt transactions. These 
transactions look like a memory transaction, except that 
DS remains High and no data is transferred. 


For tile Internal Operation transaction (Figure 52), the 
Address lines contain arbitrary data when AS goes High. 
The R/W line indicates Read (High) and the Status lines 
indicate Internal Operation (0000). 


A Halt transaction (Figure 53) is generated when the 
CPU executes a Halt instruction or when a fatal se- 
quence of traps and bus errors. occurs. The address 
placed on the AD lines is the location of the Halt instruc- 
tion or the instruction that initiated the fatal sequence of 
traps and errors. The Status lines indicate a Halt trans- 
action (0011). 


WAIT is not sampled during the Internal Operation or 
Halt transaction. 
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Figure 53. Halt Timing 


1/0 Transactions. I/O transactions (Figures 54 and 55) 
move data to or from peripherals and are generated dur- 
ing the execution of 1/0 instructions. 1/0 transactions to 
on-chip peripheral devices do not generate external bus 
transactions. 


1/0 transactions are four bus cycles long at a minimum, 
and they can be lengthened by the addition of wait 
cycles either automatically generated as indicated in the 
Bus Timing and Control register or generated by an ex- 
ternal device. The extra clock cycles allow for slower 
peripheral operation. 


The status lines indicate that the access is an 1/0 trans- 
action (0010). The 1/0 address is found on ADo-AD15 and 
A16-A23' 


Byte data (BIW = High) is transmitted on ADo-AD? This 
allows peripheral devices to attach to only eight of the 
AD lines. The ReadlWrite line (RIW) indicates the direc- 
tion of the data transfer: peripheral-to-CPU (Read: RIW 
= High) or CPU-to-peripheral (Write: RIW = Low). 
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Interrupt Acknowledge Transactions. These transac- 
tions (Figure 56) acknowledge an interrupt and read an 
identifier from the device that generated the interrupt. In- 
terrupt 
Acknowledge 
transactions 
are 
generated 


automatically by the hardware when an interrupt is 
detected. 


These transactions are five cycles long at a minimum, 
with at least two automatic wait cycles, although others 
can be added by programming the Bus Timing and Con- 
trol register. The wait cycles are used to give the inter- 
rupt priority daisy chain (or other priority resolution 
device) time to settle before the identifier is read. 
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Figure 54. I/O Write Timing 
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Figure 55. 110 Read Timing 


653 


I_TLAST-I-T1-I_T2_I_Tw_I_Tw-I_T3_1 
---1 
r 


ADO-AD15 


STATUS 
B/W = 0 
R/W = 1 


OE** 


/ 


I 


UNDEFINED· 


\ 


* AD, and AD2 Indicate the type 01 interrupt being acknowledged. 


** Z8216 only. 


m = 18 lor Z8116, 23 lor Z8216. 


I 


." 
I 


/ 


J 


/ 
DATA >- 


~ 
"- 


UNDEFINED 


STATUS VALID 


I \ 
/ \ 


Figure 56. Interrupt Acknowledge Timing 


The Status lines identify the type of interrupt that is being 
acknowledged. The possibilities are nonmaskable inter- 
rupt 
(0101) 
and 
the 
three 
external 
interrupt 


acknowledges (0100, 0101 and 0111). No address is 
generated; the contents of the bus are undefined when 
AS rises. The RIW line indicates Read (High), and the 
BIW line indicates Word (Low). . 


The only item of data transferred is the identifier that is 
captured from the AO lines on the falling clock edge just 
before OS is raised High. The length of time that OS is 
asserted is identical with 1/0 timing programmed in the 
Bus Timing and Control register. 


There are two places where WAIT is sampled and thus a 
wait cycle can be inserted by external devices. The first 
place serves to delay the falling edge of OS to allow the 
daisy chain a longer time to settle, and the second place 
serves to delay the point at which data is read. 


Refresh Transactions. A memory Refresh transaction 
(Figure 57) is generated by the refresh mechanism and . 
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can come immediately after the final clock cycle of any 
other transaction. The memory refresh counter's 10-bit 
address is output on the low order 10 bits of the bus dur- 
ing the first cycle of the transaction. The contents of the 
rest of the bus are undefined. The Status lines indicate 
Refresh (0001). This transaction can be used to generate 
refreshes for dynamic RAMs. Refreshes may occur 
while the CPU is in the Halt or Fatal state. 


CPU· Extended Processing Unit Interaction 


The l800 CPU with a loBUS interface and PAUSE input 
line (Le., the l8216) and one or more Extended Process- 
ing Units (EPUs) work together like a single CPU compo- 
nent, with the CPU providing address, status, and timing 
signals and the EPU supplying and capturing data. The 
EPU monitors the status and timing Signals output by the 
CPU so that it knows when to participate in a memory 
transaction; for EPU to memory transfers, the CPU puts 
its AO lines in 3-state while OS is Low, so that the EPU 
can use them. 
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Figure 57, Memory Refresh Timing 


In order to know which transaction it is to participate in, 
the EPU must track the following sequence of events: 


• 
When the CPU fetches the first word of an EPA in- 
struction template from memory (ST3-STO = 1101), 
the EPU must also capture the instruction returned 
by the memory. The template has an 10 field that in- 
dicates whether or not the EPU is to execute the in- 
struction. Because there is no alignment restriction 
on EPA templates, the 10 field can not be in the first 
word fetched. 


• 
The next non-refresh transaction by the CPU is the 
fetching the second word of the instruction (ST3-STO 
= 1100). The EPU must also capture this word. If 
the template is not aligned, a third fetch is made 
(ST3-STO = 1100). 


m If the instruction involves a read or write to memory, 
then transfers of data between memory and the EPU 
(ST 3-STO = 1010) are the next non-refresh transac- 
tions performed by the CPU. The EPU must supply 
the data (Write: R/W = Low) or ·capture the data 
(Read: R/W = High) for each transaction, just as if it 
were part of the CPU. In both cases, the CPU 
3-states its AD lines while data is being transferred 
(OS Low). 


2259-057 


D 
If the instruction involves a transfer from the EPU to 
the Z800 MPU, the next non-refresh transaction is 
the CPU transferring data between the EPU and CPU 
(ST3-STO = 1110). 


In order to follow this sequence, an EPU has to monitor 
the status lines to verify that the transaction it is monitor- 
ing on the bus was generated by the CPU. In a multiple 
EPU· system, there is no indication on the bus as to 
which EPU is cooperating with the CPU at any given 
time. This must be determined by the EPU.s from the EPA 
templates they capture. 


When an EPU begins to execute an extended instruction, 
the CPU can continue fetching and executing instruc- 
tions. If the EPU wishes to halt the CPU from executing 
another instruction or bus transaction, the EPU must ac- 
tivate the PAUSE line to stop the CPU until the EPU is 
ready for subsequent CPU activity. This mechanism is 
used to sy.nchronize CPU-EPU activity. 


EPU 
Transfer Transactions. These transactions 
(Figures 58-60) move data between the CPU and an EPU, 
thus allowing the CPU to transfer data to or from an EPU 
or to read or write an EPU's status registers. They are 
generated during the execution of the EPA instruction. 
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EPU-to-Memory transfers are five cycles unless extend- 
ed by Wait. Memory to EPU transfers are three cycles 
unless extended by WAIT. 


EPU-CPU transfer transactions have the same form as 
I/O transactions and thus are four clock cycles long, 
unless extended by WAIT. Although AS is asserted, no 
address is generated and the contents of the bus are 
undefined; only one status code is used (1110). 


In a multiple EPU system, the EPU that is to participate 
in a transaction is selected implicitly by the ID code in 
the EPU template, rather than by an address. The 
Read/Write line (R/W = High) indicates the direction of 
the data transfer into the CPU. 


Requests 


The Z800 MPU supports three types of request signal. 
These are: 


• 
Interrupt requests, which another device initiates 
and the CPU accepts an'd acknowledges. 


• 
Bus requests, which an external potential bus 
master initiates and the CPU accepts and 
acknowledges. 


• 
Global bus requests, which the CPU or on-chip DMA 
initiates to acquire a global system bus. 


When a request is m~de, it is. answered according to its 
type: for interrupt requests, an Interrupt Acknowledge 
transaction is initiated by the CPU; for bus requests, an 
acknowledge signal is sent; for global bus request, an 
acknowledge signal is received. 


Interrupt Requests. The Z800 MPU supports two types 
of external interrupt, maskable and nonmaskable (NMI). 
The Interrupt Request line of a device that is capable of 
generating an interrupt may be tied to any of the inter- 
rupt pins. Several d~vices can be connected to one pin, 
with the devices arranged in a priority daisy chain. The 
CPU uses the same protocol for handling requests on 
these pins. The sequence of events is given below: 


Any High-to-Low transition on the NMI input is asyn- 
chronously edge-detected, and the internal NMI latch is 
set. At the beginning of the last processor clock cycle of 
any instruction, the interrupt inputs are sampled along 
with the state of the internal NMI latch. 


If a maskable interrupt is requested and the Master 
Status register indicates that requests on that line are to 
be accepted, or if the NMI latch is set, the next possible 
bus transaction is an interrupt acknowledge transaction 
that results in an identifier from the highest-priority inter- 
rupting device being read off the AD lines. ThiS data is 
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Figure 58. EPU to CPU Timing 
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Figure 60. Memory to EPU Timing 
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used to initiate the interrupt service routine. For a non- 
maskable interrupt request in interrupt mode 0, 1, or 2, 
an interrupt acknowledge transaction is not generated; 
the hexidecimal constant 0066 is used to initiate the in- 
terrupt service routine. 


Bus Requests. To generate transactions on the bus, a 
potential external bus master (such as a DMA Controller) 
must gain control of the bus by making a bus request. A 
bus request is initiated by pulling BUSREQ Low. Several 
bus requesters can be wire ORed to the BUSREQ pin; 
priorities are resolved externally to the CPU, usually by a 
priority daisy chain. 


The asynchronous BUSREQ signal generates an internal 
BUSREQ, which is synchronous. If the external BUSREQ 
is Low at the beginning of any processor clock cycle, the 
internal BUSR6Q will cause the bus acknowledge line 
(BUSACK) to be asserted after the cu rrent bus transac- 
tion is completed or after the write transaction of a TSET 
instruction. The CPU then enters Bus Disconnect state 
and gives up control of the bus. All l800 Output pins ex- 
cept BUSACK are 3-stated. 


The on-chip DMA channels have higher priority than the 
off-chip devices requesting the external bus via 
BUSREQ. 


RESET 


A hardware reset puts the l800 MPU into a known state 
and optionally initializes the Bus Timing and Initialization 
control register of the l800 MPU to a system specifiable 
value. A reset begins at the end of any processor clock 
cycle if the RESET line is Low. However, if abus transac- 
tion is in progress it is allowed to be completed. A 
system reset overrides all other operations of the chip, 
including interrupts, traps and bus requests. A reset 
should be used to initialize a system as part of the power- 
up sequence. 


VJithin 128 processor clock cycles of the RESET line 
becoming Low, the l800 lines assume their reset values. 
For either bus, the AD lines are 3-stated, and all control 
outputs are forced High. While RESET is asserted, the 
clock output is the processor clock frequency scaled by 
fou r. RESET must be held low at least 128 processor 
clock cycles. 


The Reset line is sampled on the rising edge of the clock 
output during ·reset. When the Reset line is sampled High 
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(de-asserted), the state of th~ Wait line is also noted: if 
WAIT is asserted, then the contents of the AD lines on 
the falling edge of the clock are usedto program the con- 
tent of the Bus Timing and Initialization register, other- 
wise the constant 00 hexadecimal is used. If the hard- 
ware programming option is used, AD6 is used to enable 
the bootstrap via UART option. 


After reset, the following control registers are initialized 
as follows: 


E!I 
Program Counter, System Stack Pointer, I, and R 
registers initialized to a 


D 
Master Status register-initialized to 0, e.g., system 
mode of operation; single-step mode, Breakpoint-on- 
Halt and all maskable interrupts disabled 


It 1/0 Page register-I/O page a in use 


.. Stack Limit register cleared 


EI 
Refresh register-initialized to 88, e.g., refresh 
enabled, rate = 32 clock cycles 


II Cache Control register-initialized to 00, e.g. cache 
enabled for program only (associative rather than 
fixed location); also, all lines invalid 


CJ 
Memory Management Unit Master Control 
register-initialized to 0, e.g., translation disabled 


[] 
Trap Control register-initialized to 0, e.g., Stack 
Warning disabled, EPA disabled, 1/0 not privileged 


!ill 
All peripheral control registers-peripheral disabled 
(but see UART bootstrap option) 


D -Interrupt Status register-Interrupt Mode a 


The following registers are unaffected: 


G 
CPU register file, including user Stack Pointer 


Ii] 
Page Descriptor registers 


r::l 
Interrupt/Trap Vector Table Pointer register 


On the rising edge of RESET, if Bus Request is asserted 
the l800 MPU will grant the bus before fetching the first 
instruction from location O. 


After RESET has returned to High, the CPU begins to 
operate unless the Bootstrap UART feature is utilized. 


PIN ASSIGNMENTS 


The pin assignments of four versions of the 2800 MPU, 
the 28108, 28208, 28116 and 28216 are shown in 
Figures 61-64 respectively. 
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Figure 61. Z8108 Pin Assignments 
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Figure 63. Z811~ Pin Assignments 
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Figure 62. Z8208 Pin Assignments 
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,000 


Family 


Zilog 


Pioneering the 
Microworld 


Zilog continues its tradition of 
state-of-the-art microprocessor 
components with the introduction 
of the 32-bit Z80,OOO CPU and the 
Z8070 floating-point Arithmetic Pro- 
cessing Unit (APU). These two 
devices bring the performance of 
super minicomputers and main- 
frame computers into the realm of 
microprocessor-based systems. 
The advances in VLSI technology 
used in these integrated circuits 
herald a major breakthrough in the 
range of options available to the 
systems designer. 


The Z80,000. The Z80,OOO CPU 
provides the flexibility of a 16-bit or 
32-bit system configuration with 
the performance of a 32-bit CPU. 
Oriented to applications in which 
high throughput is required, its file 
of 16 general-purpose registers 
handles bytes, words, and long 
words with equal facility. The rich 
instruction set combines powerful 
addressing modes and operations 
in a manner that aids assembly- 
language coding of time-critical ap- 
plications, and still provides the 
completeness desirable for effi- 
cient compiler-generated code. 
The Z80,OOO CPU can be con- 


figured under software control to 
use 16-bit logical addresses (ideal- 
ly suited for high-speed controller 
applications) or 32-bit addresses 
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(for large-system tasks). The 32-bit 
address modes support both a 
linear addressing space and an 
alternative segmented addressing 
space, which are selected by the 
user according to the application's 
requ i rements. 


Other system features include 
System and Normal modes of 
operation, a sophisticated trapping 
mechanism, a high-performance 
bus structure, and built-in 
multiprocessor support. Finally, the 
device has a high-performance 
interface to the Z8070 Arithmetic 
Processing Unit so that the two 
devices can operate in tandem to 
execute floating-point instructions 
in the CPU's instruction stream. 
An on-chip cache and a memory 
management unit (MMU), coupled 
with a sophisticated instruction 
pipeline, enable the Z80,OOO to ex- 
ecute instructions at a rate of up to 


. one instruction per processor cy- 
cle. The 256-byte cache provides 
an automatic buffering mechanism 
to hold the most recently fetched 
instructions and data on the chip 
itself. Thus, subsequent references 
to these items do not require 
lengthy memory transactions but 
instead can be fetched in a single 
processor cycle. The memory 
management unit on the chip con- 
tains all the information needed to 


translate the most recently used 
logical addresses generated by the· 
CPU into the phYSical addresses 
used by the memory system. With 
each address translation, access 
attributes are automatically 
checked to determine whether or 
not the access is permitted. The 
MMU can be used to implement a 
virtual memory or can be disabled 
entirely for applications that do not 
need memory management. 


Peripheral Support. The Z80,OOO 
uses Zilog's Z-BUSTM, so the entire 
Z8000 family of circuits are 
available for use with it. Multi- 
function Z-BUS peripherals are ex- 
. tensively programmable, so each 
can be precisely tailored to an ap- 
plication. Counting, timing, and. 
parallel I/O are tasks handled by 
the Z8036 Z-CIO CounterlTimer 
and Parallel I/O Unit, which has 
three 16-bit counter/timers and 
three I/O ports. 
Data communications are the 
domain of the Z8030 Z-SCC Serial 


~ommunications Controller and the 
Z8031 Z-ASCC Asynchronous 
Serial Communications Controller, 
both dual-channel multiprotocol 
components that between them 
support all popular communication 
formats. 
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Direct melTlory access com- 


ponents are supplied by the Z8016 
Z-DTC DMA Transfer Controller, a 
fast, dual-channel device that sup- 
ports I/O-to-memory data tran$fers 
without CPU intervention. In addi- 
tion, the Z-BUS versions of the 
Z800 can be used as I/O proc- 
essors, with their on-chip DMA 
channels programmed to transfer 
data in a Z80,OOO-based system. 
General-purpose control and 
data-manipulation problems are 
solved by the Z8090 Z-UPC Univer- 
sal Peripheral Controller, a com- 
plete microcomputer-on-a-chip that 
uses the Z8 instruction set and 
features three I/O ports and two 
8-bit counter/timers. The Z8038 
Z-FIO FIFO Input/Output Interface 
Unit can be interconnected with 
asynchronous subsystems of a 
multiprocessor system to interface 
any major microproc'essor to the 
Z-BUS. Its buffer depth can be ex- 
panded using the Z8060 Z-FIFO 
Buffer Unit. Other support 
peripheral circuits that can be 
used with the Z80,OOO are the 
Z8065 Z-BEP Burst Error Processor 
and the Z8068 Z-DCP Data Cipher- 
ing Processor. 
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The Z8581 CGC,Clock Generator 
Controller can be used to generate 
the clock timing required by the 
Z80,OOO. This device uses the 
same technology as the Z80,OOO 
and provides a power-on reset 
signal and auxilary clocking 
signals. 
Finally, the Z8070 APU 
Arithmetic Processing Unit pro- 
vides the' floating-point processing 
power for the Z80,OOO CPU. 


Z8070 Arithmetic Processing 
Unit. The Z8070 Arithmetic Proc- 
essing Unit (APU) provides high- 
performance binary floating-point 
capability for the Z800, Z8000, and 
Z80,OOO CPUs. These processors 
have built-in Extended Processor 
Architecture, which enables the 
CPU and APU to function together 
to execute floating-point instruc- 
tions. I n each case, the CPU 
fetches the instruction and controls 
the data movement in the bus, 
while the APU interprets the 
instruction and performs the in- 
dicated operation. Thus, the pro- 
grammer generates one stream of 
instructions and is unconcerned 
with the mechanism for sharing the 
task .of executing the floating-point 
instructions ,in that stream. 


The Z8070 can also be used as 
an I/O device for other popular 
microprocessors. In this mode, the 
device is accessed using I/O in- 
structions to write the instruction 
command to the Z8070 and to 
move data to and from the APU. 
This mode of operation is also 
useful when the Z8070 is used in a 
bit-sliced CPU implementation to 
provide floating-point capability. 


The Z8070 follows the proposed 


IEEE P754 standard in respect to 
data formats, arithmetic opera- 
tions, and trap handling. In addition 
to single, double, and double- 
, extended floating-point formats, the 


Z8070 handles 32- and 64-bit in- 
tegers and byte strings of BCD 
digits. Add, subtract, multiply, and 
divide operations are supple- 
mented with square root, re- 
mainder, and a rich array of ,com- 
parison instructions. Finally, eight 
trapping conditions are monitored 
and trigger the device to either 
generate an interrupt request to 
the CPU or handle the trap with 
the pre-programmed, default trap 
handler on the chip. 


FEATURES 


[J 
Fast and complete implementation of proposed IEEE 
Standard P754 Draft 10.0 for Binary Floating-Point 
Arithmetic. Performs a single-precision multiplica- 
tion in under three microseconds (with a 10 MHz 
clock). 


o 
Data types supported are: Single, Double, and Dou- 
ble Extended floating-point; 16- and 32-bit integer; 
BCD strings. 


Cl 
Operations supported include add, subtract, mUlti- 
ply, divide, square root, remainder, and compare. 


GENERAL DESCRIPTION 


The Z8070 Arithmetic Processing Unit (APU) is an Ex- 
tended Processing Unit (EPU) designed to perform 
floating-point arithmetic functions while operating in 
parallel with a CPU. By monitoring the same instruction 
stream as the CPU, it is able to identify and execute 
those instructions intended for it, thereby freeing the 
CPU to perform other activities (Figure 1). 


The APU can use Zilog's Extended Processing Architec- 
ture (EPA) for the Z800, Z8000, and Z80000, or it can be 
integrated into systems based on 
other popular 
microprocessors, using a general-purpose interface. 
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[J 
Interfaces as coprocessor to Z800™, Z8000™, and 
Z80,000TM CPUs. 


D 
Speed versions offered from 10 MHz to 25 MHz. 
o 
Provides for conversion of binary integer and Binary 
Coded Decimal formats to and from floating-point 
format. 
. 


IJ 
Can be interfaced through Zilog's Extended Process- 
ing Architecture or a general-purpose interface. 


D 
Frees CPU for performance of other tasks. 


The APU supports several data formats, enabling it to 
handle a wide range of business and scientific applica- 
tions. These include three binary floating-point formats 
and four integer formats, including one for variable 
length Binary Coded Decimal (BCD) strings. All of the 
APU's internal numeric manipulations use an 80-bit 
floating-point format; however, transfers of data be- 
tween the APU's data registers and CPU registers or 
memory can use any of the formats desired, as specified 
in the floating-point instruction. 
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Figure 1_ The APU Environment 
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Floating-point arithmetic operations are perfmmed ac- 
cording to the requirements of the proposed IEEE Stan- 
dard for floating-point arithmetic. The l807a. supports: 


L!I 
Single (32-bit), Double (64-bit), and Extended (80-bit) 
Precision floating-point number formats. 


II Additior), 
subtraction, 
multiplication, 
division, 
square-root, remainder, and compare operations. 


m Conversions between different floating-paint for- 


mats. 


ARCHITECTURE 


Overview 


The l8070's contribution to a system is best understood 
by examining its structure. Internally, the l8070 is 
organized as two processors: an Interface Processor 
and a Data Processor. The two processors have 
separate clocks, freeing the Data Processor from inter- 
face speed constraints. Figure 2 is a block diagram of 
the l8070 APU. 


The Interface Processor fetches and aligns instructions 
and data, maintains the internal instruction queue, and 
executes certain control and data movement instruc- 
tions independently of the Data Processor. By monitor- 
ing CPU status and control signals; the Interface Pro- 
cessor knows when an instruction fetch is to occur and 
will watch for an Extended Instruction template. It will 
read and align the instruction and data when the Extend- 
ed Instruction template has the correct ID number. The 
user may access the status and control registers of the 
Interface Processor. 
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Figure 2. Z8070 Block Diagram 


PI 
Conversions between binary integers and floating- 
point numbers. 


II Conversions between decimal integers and floating- 


point numbers. 


• 
Non-numbers (NaNs) and infinity arithmetic. 


II Floating-point exceptions and their handling. 


The Data Processor, which operates independently of 
the Interface Processor, contains eight 80-bit data 
registers accessible to the user. It also contains the 
multiplier array, ALU, accumulator, shifter, and tem- 
porary registers required for floating-point processing. 


The only parts of the Data Processor visible to the user 
are the eight 80-bit data registers, specified in floating- 
paint instructions as source and/or destination registers, 
and the two operand registers. 


Register Organization 


There are eight 80-bit data registers, two 80-bit operand 
registers, three 32-bit status registers, and one 32-bit 
and one 16-bit control register in the l8070. All are ac- 
cessible to users with the exception of the System Con- 
figuration register, which is reserved for privileged 
users. Figure 3. illustrates the l8070 register set. 
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Figure 3. Z8070 Registers 
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Data Registers. The Z8070 has a data register file of 
eight 80-bit registers labeled FRO to FR7 (Figure 4). 


Status Registers. There are three 32-bit status 
registers: the Program Counter registers (PC1 and PC2) 
and the Flag register. 
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Figure 4. Z8070 Data Register File 


Program Counter Registers. PC1 holds the address of 
the instruction being executed in the Data Processor or 
the address of any control instruction being executed. 
PC2 holds the address of any queued instruction (Figure 
5). 


Flags Register. The Flags register (Figure 6) contains 
historical information on Z8070 operations as described 
below. 
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Figure 5. Program Counter Registers 
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Figure 6. Flags Register 


Sticky Flags (0·7). Eight flags are set when the cor- 
responding aritti"metic exception occurs, and remain set 
until they are cleared by the programmer. These flags 
are: 


INV (Invalid Operation)-Indicates an invalid operation 
or result has occurred (e.g., ...[3). 


FOV (Overflow)-Indicates that the absolute value of a 
floating-point number is too large to be accommodated 
by the destination format. 


UN (Underflow)-Occurs when the absolute value of a 
number is too small for the destination format, and fur- 
ther denormalization would cause a loss of accuracy. 


DZ (Divide by Zero)-Indicates the division of a non-zero 
finite number by zero. 


INX (Inexact Result)-Indicates when the result is inex- 
act due to rounding or an untrapped overflow. 


DE (Denormalized number)-Indicates that an operation 
was performed on a denormalized number. 


NAN (Signaling NaN)-Occurs when a Signaling NaN is 
encountered. (NaN stands for "Not-a-Number", and 
may be used to force a trap or hold other information.) 


IX (Integer Exception)-Occurs when the floating-point 
number is too large in magnitude to convert to an integer 
or BCD string, or when an attempt is made to convert a 
NaN to an integer. 
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Previous Operation Flags (8·15). The same as the 
sticky flags described above, but they reflect the excep- 
tions of the previous arithmetic operation. 


NIS1, N1S2 (16·17). Set to indicate Normal mode, and 
cleared to indicate System mode for PC1 and PC2, 
respectively. 


Compare and" Remainder Flags (18·23). Set with com- 
parisons as shown in Table 1. 


Table 1. Comparison Results 


< 
> Unordered 


Fe 
1 
0 
0 
0 
FZ 
0 
1 
0 
0 
FS 
1 
0 
0 
0 
FV 
0 
0 
0 
1 
FD 
0 
0 


FOP2E (24·25). Contains the two most significant bits of 
the exponent of operand register FOP2 for use in an 
overflow exception. 


FOP1 E (26·27). Contains the two most significant bits of 
the exponent of operand register FOP1 for I-lse in an 
overflow exception. 


R (28). Rounding bit; 1 if most recent result was rounded 
up. 
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Invalid Op (29·31). Contains a code describing the 
reason for an invalid operation result as follows: 


000 Magnitude subtraction of infinities 
·001 Zero multiplied by infinity 
010 Zero divided by zero, or infinity divided by infinity 
011 All invalid remainders 
. 
100 Unordered compare 


101 Square root of a negative number 
110 Non-decimal digit on BCD convert 


System Configuration Register. The System Con- 
figuration register is a 32-bit control register (Figure 7). 
In systems that distinguish between System and User 
modes of operation, it is restricted to privileged users. 
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Figure 7. System Configuration Register 


Interrupt· Vector (0.7). This field identifies the source I 
and cause of an interrupt. 
t 


SV (9). Set to shift the interrupt vector left one bit, and 
set the lSB to zero. 


VIS (10). Set when the interrupt vector is to include 
status information. 


NV (11). Set when there is no interrupt vector (leaves 
'lines 3-stated). 


DLC (12). Set to disable' interrupts from lower priority 
devices on the interrupt daisy chain. 


IUS (13). Set when 'the interrupt is under service. 


IP (14). Set to indicate a pending interrupt. 


MIE (15) .. Set to enable interrupts. 


INTACK (16·17). Set to indicate which type of interrupt 
acknowledge to respond to as follows: 


Ox = Nonmaskable 
10 = Nonvectored 
11 = Vectored 


OVRLP (18·19). Indicates the Overlap mode as follows: 


Ox = No Overlap 
10 = Intermediate Overlap 
11 = Maximum Overlap 


AC (20). Set to synchronize processors if ClK.1 (inter- 
face' clock) and ClK.D (data processor clock) are run- 
ning at different speeds. 


F (21). Set if an interrupt service routine will be unable to 
successfully return to the interrupted program. This hap- 
pens when two or more floating-point instructions have 
been fetched after the EPU instruction qausing the inter~ 
rupt, but before the interrupt acknowledge. 


RPC (22). Set if an interrupt service routine will need to 
alter its return address to successfully continue the in- 
terrupted program. 


U (23). Set when the Z8070 is used. 


IR (24·25). Set to indicate the reason for an interrupt as 
follows: 
' 
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00 = Arithmetic 
01 = Invalid opcode 
10 ;:: Invalid EPU ID 
11 = Privileged mode violation 


ID (26·27). These bits hold the I D of the Z8070 expressed 
in binary form and are set on power-up with the ID pins. 
Instructions are executed only if the ID in the opcode 
matches these bits. 


EPUID (28·31). This field contains four bits, one for each 
possible EPU ID. An instruction specifying an ID whose 
corresponding bit is a 1 will cause an Invalid EPU ID in- 
terrupt. 


User Control Register. The User Control register 
(Figure 8) is a 16-bit register, accessible to all users. The 
user controls rounding modes and enables and disables 
traps with this register. 
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Figure 8. User Control Register 


RM (0·1). Sets the rounding modes as follows: 


00 = Round to Nearest 
01 = Round toward Zero 
10 = Round toward Positive Infinity 
11 ~ Round toward Negative Infinity 


Trap Enables (8·15). The setting of these bits enables 
the trap associated with each exception listed below. 


INV (Invalid) 
FOV (Overflow) 
UN (Underflow) 
DZ (Divide-by-Zero) 
INX (Inexact result) 
DE (Denormalized number) 
NAN (Signaling NaN) 
IX (Integer Exception) 
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Floating Operand Registers. The ZS070 contains two 
SO-bit Floating Operand registers (Figure 9), labeled 


79 78 
64 63 


FOP1 and FOP2, which contain the input operand (FOP1) 
and the default result (FOP2) for use by trap handlers. 
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Figure 9. Floating Operand Registers 


PROGRAMMING 


Floating-point instructions are contained in the same 
program as standard CPU instructions. To the program- 
mer, instruction execution appears linear, as if a single 
processor is executing all the instructions. In many 
cases however, CPU and Z8070 processing can occur in 
parallel, greatly increasing system throughput. 


Parallel processing depends upon the type of APU in- 
struction being executed and the Overlap mode in effect. 
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APU/CPU PROCESSING IN AN OVERLAP MODE 


If the APU receives an instruction involving a data 
transfer out of the APU, it halts the CPU (asserts BSY) 
regardless of the Overlap mode in effect. When No- 
Overlap mode is in effect, the APU asserts BSY 
whenever any floating-point instruction is received. 
Figure 10 illustrates instruction processing with and 
without overlap. 
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Figure 10. Instruction Processing 
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In general, the interaction of CPU and APU is 
transparent to the user. It is possible, however, to ar- 
range programs to· take advantage of the parallel pro- 
cessing capabilities inherent in the system. 


An interleaving of CPU and l8070 instructions enhances 
the ability of a system to process in parallel. Without in- 
terleaving, floating-point instructions .might be received 
faster than they can be processed, forcing the l8070 to 
halt further CPU processing until the current extended 
instruction is completed. Also, some instructions take a 
relatively long time to process (e.g., FSQR, FDIV); in- 
terleaving allows the CPU to process instructions while 
these extended instructions are being processed by the 
APU. 


Parallel processing is facilitated by interleaving instruc- 
tions as in 


FADD 
F1 @92 


INC 
R24 
FLD 
@R4 F1. 


!APU instruction! 
!CPU instruction! 
!APU instruction! 


since the incremen't of R2 can occur while the floating 
point add is finishing. 


Programming constructions like the following 


FADD 
F1 @R2 
FLD 
@R4 F1 


cause the l8070 to halt the CPU to ensure that valid 
results are read from F1 during the subsequent store 
operation. 


Data Types and Formats 


This section describes the different data types and for- 
mats that the APU is able to manipulate. These data 
types include binary· floating-point and binary and 
decimal integers, and can be represented in 32-, 64-, and 
80:bit formats. 


Binary Floating·Point. All binary floating-point numbers 
assume the followin·g format: 


Is I e 


where the ·S .bit is the Sign bit and specifies a positive 
(cleared to 0) or negative (set to 1) number. The negative 
or positive floating-point number is equal to: 


Significand x 2(exponent-bias) 
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The significand portion contains the fraction and the in- 
teger bit (in Single and Double Precision binary, the in- 
teger bit is implicit). The significandthen, is the integer 
bit followed by the binary point and the fraction. The ex- 
ponent locates the actual binary point, and the sign bit 
specifies a positive or negative number. 


In the following description of the binary floating-point 
formats, "s" is the sign, "e" is the exponent, "f" is the 
fractional part of the significand, and "j" is the integer 
part (possibly implicit) of the significand. 


The value (v) of the 32-bit Single Precision Binary format 
is determined as follows: 


• 
If e = 255 and f =1= 0, then v = NaN. 


II If e = 255 and f = 0, then v = (- 1 )S(infinity). 


• 
If 0 < e < 255, thEm v = (-1)S2e-127(1.f). 


• 
If e = 0 and f =1= 0, then v = (-1)s2e-126(0.f). 


• 
If e = 0 and f = 0, then v = (- 1 )SO,(zero). 


The value of the 64-bit Double Precision binary format is 
determined as follows: 
.If e = 2047 and f =1= 0, then v = NaN. 


• 
If e = 2047 and f = 0, then v = (-1)S(infinity). 


• 
If 0 < e < 2047 then v = (- 1 )S2e-1023(1.f). 


m If e = 0 and f =1= 0, then v = (-1)s2e-1022(0.f). 


• 
If e = 0 and f = 0, then v = (- 1 )SO,(zero). 


For the 80-bit Double Extended Precision Binary format, 
the value is determined as follows: 


• 
If e = 32,767 and f =1= 0, then v = NaN. 


II If e = 32,767 and f = 0, then v = (-1)S(infinity). 


11 
If 0 < e < 32,767 then v = (-1)s2(e-16,383) U.f). 


• 
If e = 0 andj = f = 0, then v = (-1)sO, (normal 
zero). 
' 


• 
If e = 0 and j or f is nonzero, then v = 
( - 1 )s2e-16,383U.f). 


The exponent is always biased to ensure a positive value 
for the purpose of comparisons. Numbers of the same 
format may then be compared bit by bit from left to right, 
the first difference determining the ordering. The biases 
for the floating-point formats are shown in Table 2. 
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Tabla 2. Exponent Biases 


Format 


Single 


Double 


Extended 


Exponont Bins 


127 


1023 


16,383 


An exponent of all ones indicates an infinity if the frac- 
tion equals zero, or a NaN if the significand is not'zero. A 
Signaling NaN is indicated by the most significant bit 
(MSB) of the fraction field being zero, and a Quiet (non- 
trapping) NaN is indicated by the MSB of the fraction be- 
ing one (in Extended format, Quiet vs. Signaling is deter- 
mined by bit 62). Single, Double, and Extended formats 
are shown in Figure 11. 


31 30 
23 22 


SINGLE PRECISION BINARY (32 BITS) 


63 62 
52 51 


DOUBLE PRECISION BINARY (64 BITS) 


79 78 
64 63 62 


e 


Integers. Integer formats are automatically converted to 
the aO-bit binary floating-point format when they are 
loaded into the APU (instructions FLDIL, FLDIQ, and 
FLO BCD). 


Decima/Integers. The Decimal Integer format is one to 
ten bytes,' which includes up to 19 Binary Coded Decimal 
(BCD) digits and a Sign bit. The Decimal Integer format is 
illustrated in Figure 12. 


Binary Integers. The Long Word and Quad Word Integer 
formats are shown in Figure 13. These are the only for- 
mats which express negative numbers in two's comple- 
ment form. 


EXTENDED PRECISION BINARY (80 BITS) 


Figure 11. Binary Floatlng·Polnt Format~ 


79 
75 


/S I 
X I 
X I x I 
UP TO 19 BCD' DIGITS 


s = sign bit 
e = exponent lIeld 
f = fraction lIeld 
J = Integer bit. 


31 


63 


2235-009, 2146-001 


BINARY CODED DECIMAL INTEGER 


Figure 12. Binary Coded Decimal (BCD) Integer Format 


BINARY INTEGER (32 AND 64 BIT TWO'S COMPLEMENT INTEGERS) 


Figure 13. Long·Word and Quad·Word Integer Formats 


o 
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Addressing Modes 


Operands are specified in a floating-point instruction 
with the addressing modes for each CPU option as 
shown in Table 3. 


Table 3. Addressing Modes 


Addressing Mode 


Z8070 Register 
CPU Register 
Indirect Register 
Direct Address 
Index 
Immediate 
Relative 
Stack Pointer 
Relative 


Base Index 


F = APU register 
CPU = CPU register 
M = memory 


Universal 


F 


CPU 


M 
M 
M 
M 
M 


M 
M 


zaoo 
zaooo 


F 
F 
R 
R 


IR 
IR 


DA 
DA 
X 
X 


RA 


S 
BX 


Primary Arithmetic Operations 


zao,ooo 


F 
R 
IR 
DA 
X 


1M 


Assembler Syntax 


Floating-point instructions are of the form: 


FXXX[S,D] rnd dst,src 


The opcode suffix [Single (S), Double (D), or Extended 
(no suffix)], refers to the size of the source operand. 
"rnd" refers to the precision to which the result of the 
operation is rounded. SGL is single precision, DBL is 
double precision, and no suffix is extended precision. 


Instruction Set 


, The floating-point instruction set provides the following 


types of instructions: 
. 


• 
Primary arithmetic operations 


II Load and store operations 


iii 
Compare operations 


Ii] 
Secondary arithmetic operations 


E1 
Control operations 


Mnemonic 
Operands 
Addressing Modes 
Operation 
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FADD 
FADDS 
FADDD 


FDIV 
FDIVS 
FDIVD 


FMUL 
FMULS 
FMULD 


FREMSTEP 


FREMSTEPF 


FSQR 
FSQRS 
FS9RD 


FSUB 
FSUBS 
FSUBD 


dst, src 


dst,src 


dst, src 


dst, src 


dst, src 


dst,src 


dst, src 


src: F,CPU,M 


dst: F 


src: F,CPU,M 


dst: F 


src: F,CPU,M 


dst: F 


src: F,CPU,M 
dst: F 


src: F 
dst: F 


src: F,CPU,M 


dst: F 


src: F,CPU,M 


dst: F 


Floating Add 


dst - 
dst + src 


Floating Divide 


dst - 
dst/src 


Floating Multiply 


dst - 
dst*src 


Floating Remainder Step 


dst - 
dst REM src 


Floating Remainder Step and 
Transfer Flags to CPU 


dst - 
dst REM src 
CPU - 
Flags 


Floating Square .Root 


dst - 
SQR (src) 


Floating Subtract 


dst - 
dst - 
src 


Load and Store Operations 


Mnemonic 
Oporands 
Addressing Modes 
Operation 


FLO 
dst, src 
src: F,CPU,M 
Floating Load 


FLDS 
dst: F 
FLDD 
or 
dst - 
src 
src: F 
dst: CPU,M 


FLO BCD 
dst, src 
dst: F 
Floating Load BCD Integer 


src: CPU,M 
or 
dst - 
Float (BCD-src) 
dst: CPU,M 
dst - 
BCD (float-src) 


src: F 


FLDIL 
dst, src 
dst: F 
Floating Load Binary Integer 
Long Word 
~ 


src: CPU,M 
I 
or 
dst - 
Float (src) 
dst: CPU,M 
dst - 
Fix (src) 
~ 
src: F 
tg 
e= 
FLDIL 
dst, src 
dst: F 
Floating Load Binary Integer 
Long Word 
src: CPU,M 
·or 
dst - 
Float (src) 
dst: CPU,M 
dst - 
Fix (src) 
src: F 


FLDIQ 
dst,src 
dst: F 
Floating Load Binary Integer 
Quad Word 
src: CPU,M 
or 
dst - 
Float (src) 
dst: CPU,M 
dst - 
Fix (src) 
sdc: F 
(note: CPU = 64-bit 
register) 


FLDM 
dst, src, n' 
dst: F 
Floating Load Multiplo 


(n = 1,2) 
src: CPU,M 
or 
dst - 
src 
dst: CPU,M 
src: F 
(note: F,CPU,M = 80- 
or 160-bit location) 


FLDTL 
dst, src 
dst: CPU,M 
Floating Load and Truncate to 
src: F 
Integer Long Word 
(note: dst is 32 bits) 
dst - 
Int (src)· 


FLOTO 
dst, src 
dst: CPU,M 
Floating Load and Truncate to 
src: F 
Integer Quad Word 
(note: dst is 64 bits) 
dst - 
Int (src) 
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Compare Operations 


Mnemonic 
Operands 
Addressing Modes 
Operation 


FCP 
dst, src 
dst: F 
Floating Compare 


FCPS 
FCPD 
src:F,CPU,M 
dst - 
src, set APU flags 


FCPF 
dst, src 
dst: F 
Floating Compare and Transfer 
src: F 
Flags to CPU 


dst - 
src 


CPU - 
flags 


FCPFX 
dst, src 
dst: F 
Floating Compare, Transfer Flags to 
src: F 
CPU, and Raiso Exception if 
Unordered 


dst - 
src 


CPU - 
flags 


FCPX 
dst, src 
dst: F 
Floating Compare and Raise 


FCPXS 
Exception if, Unordered 


FCPXD 
src: F,CPU,M 


dst - 
src, set APU flags 


FCPZ 
dst, src 
dst: F,CPU,M 
Floating Compare with Zero 
FCPZS 
FCPZD 
dst - 
0, set APU flags 


FCPZF 
dst 
dst: F 
Floating Compare with 0, and 
Transfer Flags to CPU 


dst - 
0 
CPU - 
flags 


FCPZFX 
dst 
dst: F 
Floating Compare with 0, Transfer 
Flags to CPU, and Raise Exception 
if Unordered 


dst - 
0 
CPU - 
flags 


FCPZX 
dst 
dst: F,CPU,M 
Floating Compare with Zero and 


FCPZXS 
Raise Exception if Unordered 
FCPZXD 
dst ,- 0 
set APU flags 
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Secondary Ari~hr(.eiic Opera~ions 


iv1nemonic 
Operands 
Addressing Modes 
Operation 


FABS 
dst, src 
dst: F 
Floating Absolute Value 


FABSS 
FABSD 
src: F,CPU,M 
dst - 
I src I 


FCLR 
dst 
dst: F 
Floating Clear 


dst - 
+0 


FINT 
dst, src 
dst: F 
Floating Round to Floatin_g Integer 
FINTS 
FINTD 
src: F,CPU,M 
dst - 
Float [Int (src)] 


FNEG 
dst, src 
dst: F 
Floating Negation 


FNEGS 
00 


FNEGD 
src: F,CPU,M 
dst - 
(-src) 


~ 
Conirol Opera~ions 
00 • 
~ 


Mnomonic 
Operands 
Addressing Modes 
Operation 
ra 
d 


FLDCTL 
dst, src 
dst: FCTL 
Floating Load Control 
src: CPU,M 


or 
dst - 
src 


dst: CPU,M 
src: FCTL 


FLDCTLB 
dst 
dst: Fsel 
Floating Load Control Byte 


CPU - 
flags 


FRESFLG 
src 
dst: FFLAGS 
Floating Reset Flag 
src: flaglist 
FFLAGS (flaglist) - 
0 


FRESTRAP 
src 
dst: USER 
Floating Reset Trap 
src: traplist 
USER (traplist) - 
0 


FSETFLG 
src 
dst: FFLAGS 
Floating Sot Flag 
src: flaglist 
FFLAGS (flaglist) - 
1 


FSETMODE 
src 
dst: FMODE 
Floating Set Mode 
src: modelist 
FMODE - 
modelist 


FSETTRAP 
src 
dst: USER 
Floating Sot Trap 
src: traplist 
USER (traplist) - 
1 
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SIGNAL DESCRIPTIONS 


The following section describes each pin function of the 
Z8070 APU. Depending on which CPU option is chosen 
(pins OPTo and OPT1), some of these functions do not ap- 
ply. Figure 14 shows a Z8070 pin-out with pin 
assignments, and Figure 15 gives the functional pin-out 
for each of the four possible interface options. 


ABORT. Abort (input, active Low). ABORT is asserted to 
cause an instruction abort. 


ADo-AD31. Address/Data (inputs/outputs, active High, 
3-state). Multiplexed address .and data lines. 


AS. Address Strobe (input, active Low). The rising edge 
of AS indicates the beginning of a transaction and show's 
that the address, status, and control signals are valid. 


BLIW and BWiL. Byte, Word, and Long Word (inputs). 
These signals specify the data transfer size as follows: 


BUW 
Bwi[ 
1 
1 
o 
1 
1 
a 


Size In bits 
8 
16 
32 


BRST. (Burst, input, active Low). BRST active indicates 
that the CPU may generate burst transfers. 
--- 
BRSTA. Burst Acknowledge (input, active Low). A Low 
on BRSTA indicates that the memory can support burst 
transfers. 


BSY. Busy (output, active Low). The BSY signal is used 
by the Z8070 to halt the CPU during stores, and also to 
implement overlap functions. It is associated with the 
following CPU signals: 


CPU 
Z800 
Z8000 
Z80,000 


Signal 
PAUSE 
STOP 
EPUBSY 


BUSACK. Bus Acknowledge (input, active Low). When 
BUSACK goes Low, the EPU 3-states the AD lines until it 
goes High again and an EPU-to-memory or CPU transfer 
is required. 


ClK.D. Data Processor Clock (input). CLK.D is provided 
by the system and runs the data processor portion of the 
Z8070. 


ClK.I. Interface Processor Clock (input). Interface Pro- 
cessor clock of the Z8070. 


CS. Chip Select (input, active Low). CS signals the begin- 
ning of a Z8070 transaction and is valid only for the 
length of a single transaction or machine cycle. 


DBo-DBn. Data Bus (input/outputs, active High, 3-state). 
These are the data lines for the Universal interface, 
where n=7, 15 or 31. 


OS. Data Strobe (input, active Low). DS provides timing 
for data transfers on the bus. 
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100-101' 10 Select· (inputs, active High). These signals 
establish the EPU ID during reset. 


lEI. Interrupt Enable In (input, active High). lEI is used 
with lEO to form an interrupt daisy chain when there is 
more than one interrupt-driven device sharing a common 
interrupt request line to the CPU. A High lEI indicates 
that no other higher priority device has an interrupt 
under service. 


lEO. Interrupt Enable Out (output, active High). lEO is 
High only if lEI is High and the CPU is not servicing a 
Z8070 interrupt and the Z8070 is not requesting an inter- 
rupt (Interrupt Acknowledge cycle only). lEO is con- 
nected to the next lower priority device's lEI input and 
thus inhibits interrupts from lower priority devices. lEO is 
tied high for the last device on the chain. 


INT. Interrupt Request (output, open-drain, active Low). 
This signal is activated when the Z8070 requests an in- 
terrupt. 


NtS'. Normal/System mode (input). High for Normal 
mode, Low for System mode. 


OPTo-OPT1. CPU Option (input, active High). These 
signals establish the CPU option during reset as follows: 


OPTo 
a 
a 
1. 
1 


OPT1 
a 
1 a 
1 


CPU Interface 


Universal 
Z80,000 
Z800 
Z8000 


RESET. Reset (input, active Low). When asserted, 
RESET forces a hardware reset to power-on condition. 


RSPo-RSP1. Response (input, active High). These lines 
encode the response monitored by the APU to transac- 
tions initiated by the Z80,000 CPU as follows: 


RSPo 
RSP1 
a 
1 
Bus Error 
1 
a 
Bus Retry 
a 
a 
Wait 
1 
1 . 
Ready 


RIW. Read/Write (input, Low = Write). Indicates whether 
the CPU is performing a read or write operation. 


SIP. Sequence in Progress (output, active Low). This 
signal is asserted by the APU and held Low until the in- 
struction and any associated data transfer is completed. 


SNo-SNs. Segment Number (input, active High). These 
lines contain the segment number portion of a memory 
address. 


STo-ST3. Status (input, active High). These lines specify 
the type of bus transaction as described in the ap- 
propriate CPU Technical Manual. 


BUSACK 


BRSTA 


SIP/BRST/ABORT 
Riw 


GNO 


Cs/As 


AD27 (SN21 


AD28 (SNal 
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AOao (SNsl 
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Z8070 APU 


101 


RESERVED 


100 


INT 


lEI 


GND 


lEO 


RESET 


OPT1 


OPTO 


Figure 14. Pin Assignments 


EXTERNAL INTERFACE 


The four different interfaces for the Z8070 are the Z800, 
Z8000, Z80000, and Universal interface. The Z800, 
Z8000, and Z80000 are Z-BUS® type interfaces with the 
CPU and APU fully interlocked in hardware. No software 
polling or wait instructions are required to prevent over- 
running of the Z8070's instruction queue with the Z-BUS 
interfaces. Depending on the type of system, the Univer- 
sal interface may require additional logic to implement 
the interface. In general, APU-memory transactions are 
performed with the same bus cycles as CPU-memory 
transactions. The following sections describe interface 
specific features of the Z8070. 


Interface Types 


Z·BUS Interface. An important feature of the Z-BUS 
CPUs (Z800, Z8000, and Z80000) is their Extended Pro- 
cessing Architecture (EPA). This facility provides a 
mechanism by which the basic instruction set can be ex- 
tended via external EPUs such as the Z8070 APU. 


The execution of floating-point instructions is controlled 
by an extended processor enable bit in the CPU. When 
this bit is zero, it indicates that there is no EPU con- 


2235·010 


nected to the CPU, causing the CPU to trap to a software 
trap handler whenever an extended instruction is en- 
countered. This allows the operation of the extended in- 
struction to be performed by software, and provides the 
ideal tool for emulating an EPU during development of 
systems intended to later contain an EPU. 


If the extended instruction indicates a transfer of data 
between the Z8070's internal registers and the main fJ 
memory, the CPU will calculate the memory address and 
generate the appropriate timing signals (AS, OS, MREQ, 
etc.), but the data transfer itself is between the Z8070 
and memory (over the AD lines). If a transfer of data be- 
tween the CPU and APU is indicated, the sender places 
the data on the AD bus while DS is active. 


If the extended instruction indicates an internal opera- 
tion to be performed by the Z8070, the Z8070 begins ex- 
ecution of the task and the CPU is free to continue on to 
the next instruction. Processing then 
proceeds 


simultaneously in both the CPU and the Z8070 until a se- 
cond extended instruction is encountered that is destin- 
ed for the Z8070. 
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The Extended Processing Architecture also offers a pro- 
vision to preclude extended instruction overlapping. The 
APU connects to the CPU via the BSY line so that if the 
APU is requested to perform a second extended instruc- 
tion before it has completed the previous one, it can halt 
the CPU until execution of the previous instruction is 
complete. BSY is also asserted when a store opcode is 
received by the APU, ,and it is held active until the re- 
quested data is ready for the CPU to transfer. 


With the Z800 interface, the CPU indicates an instruction 
fetch to the APU whenever it places a floating-point iR- 
struction on the bus. The Z8070 then translates the in- 
struction and performs the operation, asserting BSY if 
the opcode indicates a store. 


For the Z8000 interface, if the EPA bit is set it indicates 
that an EPU is connected to the CPU. The CPU begins 
operation by fetching an instruction and determining 
whether it is a CPU or an EPU command. The EPU 
monitors the Z-BUS at the same time, looking for an ex- 
tended instruction template. The CPU performs any ad- 
dress calculations required by the extended instruction 
and, if the instruction specifies the transfer of data, the 
CPU generates the timing signals for the transfer. 


The Z8070 monitors the activity on the Address/Data 
(AD) bus. If the instruction fetched is an extended in- 
struction, all EPUs and the CPU latch the instructiort If 
the Z8070 is not busy when the instruction and data in- 
tended for it appear, the floating-point instruction is ex- 
ecuted. If the Z8070 is busy, the CPU is stopped until the 
Z8070 is no longer busy. 


The Z80,OOO CPU differs slightly from the Z800 and 
Z8000 CPUs described above. When the Z80,OOO CPU 
detects an extended instruction, it first samples BSY. If 
BSY is inactive, the CPU signals an EPU transaction 
(status 0100) and places the extended instruction on the 
AD bus. If BSY is active, the CPU samples BSY every 
bus clock cycle until it is inactive. The CPU may 
acknowledge bus requests or interrupt requests during 
this period, and if this should happen before all 
associated data transfers are complete, the CPU saves 
the address of ,the extended instruction. 


Universal Interface. With the Universal interface, the 
Z8070 does not monitor the bus but, rather, waits until its 
CS line becomes active, indicating that the instruction on 
the bus is intended for it. The APU then reads data from 
the bus during each Data Strobe until it has collected the 
full instruction and associated data. The decoded in- 
struction informs the Z8070 of the type of operation it is 
to perform. When CS goes Low, it forces the Sequence 
in Progress Signal (SIP) Low, and SIP stays Low until the 
last bus transaction associated with the instruction is 
complete. 


The Universal interface can be set for a data bus width of 
8-, 16-, or 32-bits with the BLlW and Bwi[ pins. A set of 
interrupt control signals (INT, lEI, lEO) permit the in- 
tegration of the Z8070 in a daisy-chain priority interrupt 
scheme. 
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Bus Transactions 


The following section describes bus transactions for the 
Z800, Z8000, Z80,OOO,and Universal interfaces. 


2800/Z8070 Bus Transactions. The 16-bit Z800 MPUs, 
Z8116 and Z8216, incorporate Zilog's Extended' Pro- 
cessing Architecture (EPA) for Extended Processing 
Units. The Z8116 is a 40-pin device that contains an 
MMU, clock oscillator, and refresh controller on-Chip. It 
does not have a PAUSE input. The Z8216 is a 64-pin 
device which additionally contains four DMA channels, 
four counter/timers, and a UART, and does have a 
PAUSE input. When the Z800 encounters an EPU in- 
struction, it fetches the following EPU template from 
memory with instruction fetch status. (The opcode and 
addressing mode portion of the instruction may be ex- 
ecuted from cache, but the template will always be fet- 
ched from memory with status 1101 or 1100). When an 
EPA template with the appropriate ID number is 
detected, the Z8070 obtains or places data or status in- 
formation on the bus using the Z800generated control 
signals and performs its function as directed. 


The Z800,MPU is responsible for instructing the APU and 
delivering operands and data to it. The Z8070 recognizes 
templates intended for it and executes them, using data 
supplied with the template and/or data within its, internal 
registers. There are three classes of APU instructions: 


• 
Data transfers between main memory and APU 
registers. 


r.! 
Data transfers from APU registers to the CPU's ac- 
cumulator. 


• 
APU internal operations. 


Six Z800 addressing modes may be utilized with 
transfers between APU registers and the CPU and main 
memory: 


.. Direct Address 


• 
Indirect Register 


• 
Indexed 


II Relative 


II Stack Pointer Relative 


II Base Index 


The Z8070 connects to the Z800 via the BSY (PAUSE) 
Signal, so that if the APU is requested to perform a sec- 
ond floating-point instruction before it has completed the 
previous one, it can stop the CPU until execution of the 
previous floating-point instruction is complete. BSY will 
also be asserted if the instruction is a store. 


Z8070/Z800 instruction execution is illustrated in Figure 
16. The Z800 begins operation by fetching an instruction 
and determining whether or not it is an extended instruc- 
tion. If it is, the state of the EPU Enable bit in the Trap 
Control register is examined. If the EPU Enable bit is 


zero, The CPU generates a trap and may simulate the 
APU in software. If the EPU Enable bit is set to 1, the four 
byte EPA template is fetched from memory, with 1 1 a. a 
indicated on status lines 8To-8T3. After fetching the 
template, the l800 will; if necessary, transfer ap- 
propriate data between the CPU and memory or be- 
tween the CPU and the APU. If the APU is not busy when 
the data and template for it appear, the template is ex- 
ecuted. If the APU is still processing a previous instruc: 
tion, it asserts B8Y to halt further execution of CPU in- 
structions until execution is complete. After the execu- 


Tn 
T, 


CLOCK _ 
I 
I 


WAIT 


STATUS 
(BNi, Nis, 
5To-5T3) 


SNo-SNo 
SEGMENT NUMBER 


AS 


-- 
MREQ 


/ 


tion of the template is complete, the APU releases the 
B8Y line and CPU instruction execution continues. 


APU to CPU transfer transactions (Figure 16) have the 
same form as 1/0 transactions, and thus are four clock 
cycles long (unless extended by WAIT). 8T3-8To = 
1110, and the CPU output R/W indicates the direction of 
data transfer. A l8070-memory read· is illustrated in 
Figure 17 and a l8070-memory write is illustrated in 
Figure 18. 
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Figure 17. Z8070·Memory Read Transaction (Z800) 


I_T1-I-Tw-'I_T2_I_T3_I_TW~1 
~ 
l 
I 
I 
I 
I 
- K 
ADDRESS 
\ 
/ 
EPU DATA VALID 
\. 
I 
\ 
/ 


- 
-- rL..I 
- 


STATUS VALID = 1010 
- 


/ 
\ 


I 
I 
I 
I 
1 
1 


Figure 18. Z8070·Memory Write Transaction (Z800) 
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Z8000/Z8070 Bus Transactions. l8000/l8070 transfer 
transactions move data between the APU and CPU or 
·between the APU and memory. The CPU can transfer 
data to or from the APU, and provides address and bus 
control signals for transfers between the APU and 
memory. 


When the l8070 is to participate in a memory transac- 
tion, the l8000 places its AD (Address/Data) lines into 
the high impedance state while OS is Low, so that the 
l8070 can use them. APU-memory transfer transactions 
are the same as CPU-memory transactions (Figure 19). 
The CPU generates the address, and status codes 1010 
and 1011 are used. APU-CPU transactions have the 
same timing relationship as I/O transactions (Figure 20). 


In order to know which transaction it is to participate in, 
the l8070 tracks the following sequence of events: 


1. 
When the CPU fetches the first word of an instruc- 
tion (ST3-STO = 1101), the APU must also capture 
the instruction returned by memory. If the instruction 
is an extended instruction, it will have an 10 field 
which indicates whether or not the APU is to execute 
it. 


2. 
If the instruction is to be executed by the APU, the 
next non-refresh transaction by the CPU fetches the 
second word of the instruction (ST 3-STO = 1100). 
The APU also captures this word. 


3. 
If the instruction involves a read or write to memory, 
there will b~ zero or more program fetches by the 
CPU (ST3-STO = 1100) to obtain the address portion 
of the extended instruction. The next 1 to 16 non- 
refresh transactions by the CPU will transfer data 
between memory and the APU. The APU supplies 


the data (R/W Low) or captures the data (R/W High) 
for each transaction. In both cases the CPU 3-states 
its AD lines while data is being transferred (OS Low). 
APU memory transfers are always word oriented 
(B/W Low). 


4. 
If the instruction involves a transfer between the 
CPU and APU, the next 1 to 16 non-refresh trans- 
actions by the CPU transfer data between the APU 
. and CPU (ST3-STO = 1110). 


To follow the above sequence, the l8070 has to monitor 
the BUSACK line to verify that the transaction on the bus 
is generated by the CPU. There is no indication on the 
bus as to which EPU in a multiple EPU system is 
coopcrrating with the CPU-this must be determined 
from the opcodes and 10 fields of the extended instruc- 
tion the APU captures. 


With the first two instruction words, the l8070 deter- 
mines: 


[J 
Whether or not a memory access will be made. 


CJ 
The number of words of data to be transferred for 
APU-memory or APU-CPU transfers. 


[J 
The operation to be performed on the data. 


A final aspect of l8000/Z8070 interaction is the use of 
the BSY (STOP) signal If the system is in Non-Overlap 
mode, the APU asserts BSY to stop the CPU whenever it 
receives a floating-point instruction and its associated 
data. If overlapping is allowed, when the l8070 begins to 
execute a floating-point instruction the CPU can con- 
tinue fetching and executing instructions. If the CPU 
fetches another floating-point instruction before the first 
one has completed execution, the APU asserts BSY until 
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Figure 19. Z8070·Memory Transfer Transaction (Z8000) 
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execution of the previous floating-point instruction is 
complete. (In Intermediate Overlap mode BSY is not 
asserted until a third APU instruction is fetched;) BSY is 
always asserted if an instruction involves a store. 


Z80,OOO/Z8070 Bus Transactions. When the Z80,000 
CPU encounters an EPA instruction and the EPA bit in 
the FCW is set to 1, the CPU broadcasts the first two 
words of the instruction to the EPUs in the system using 
the CPU-EPU instruction transfer transaction. All EPUs 
in the system recognize the transaction, but the APU is 
chosen specifically in bits 16 and 17 of the EPU instruc: 
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tion. The Z80,000 also transfers the PC value for the in- 
struction, which the APU saves for use in exception 
handling. If data transfers are required to complete the 
instruction, the Z80,000 controls the data transfer trans- 
actions while the Z8070 drives or receives the data. 


The signal BSY, output from the APU and wired to the 
CPU's EPUBSY pin, is used to synchronize the CPU and 
APU in executing floating-point instructions. The CPU 
must sample BSY inactive before initiating an APU in- 
struction transfer. If data transfers are required, the CPU 
must sample BSY inactive before initiating the transfer. 
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Figure 20. Z8070·Z8000 Transfer Transaction 
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BSY is also used to control the degree of overlap be- 
tween CPU and APU instruction processing. Ordinarily 
the CPU can continue processing other instructions after 
performing the data transfers associated with a floatin-g 
point instruction, and before the APU has completed ex- 
ecuting the instruction. To simplify debugging and 
recovery from exceptions, a Non-Overlap mode is pro- 
vided, controlled by the EPU.O bit in the Z80,000 Hard- 
ware Interface Control Register. In Non-Overlap mode, 
the CPU samples BSY in the middle of the bus cycle in 
which the last data transfer for an extended instruction 
occurs. If BSY is asserted, the Z80,000 ceases process- 
ing instructions or interrupts until BSY is sampled inac- 
tive in ttie middle of a bus cycle. 


CPU·APU Instruction Transfer Transactions. Timing 
for a CPU-APU instruction transfer transaction, with 


status 0100, is shown in Figure 21. The transaction 
begins with Address Strobe to indicate the AD lines and 
status are valid. During T1 the AD lines are used to 
transfer the opcode, which is the first two words of the 
EPA instruction. At the beginning of T 2 the CPU stops 
driving the opcode, asserts OS, and starts driving the PC 
on the AD lines. 


CPU·APU Data Transfer Transactions. Transactions 
to transfer data between the CPU and APU use status 
0001. The number of words transferred is known to the 
CPU and EPU from the EPA instruction opcode (n-1 
field). The transactions transfer one or more longwords 
of data until all words have been transferred. If the last 
transfer contains only a word, the data is replicated on 
ADo-AD15 and AD16-AD31. The CPU does not assert 
BRST and ignores RSPo-RSP1 and BRSTA. 
r 
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Figure 21. Z8070·Z80,OOO Instruction Transfer 
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CPU·APU Da'ta Read. Timing for a CPU-APU -data read 
transaction is shown in Figure 22. This example has two 
data transfers; any. number of data transfers between 1 
and 4 is possible. The transaction begins with Address 
Strobe to indicate that the status and control signals are 
valid. The CPU stops driving the AD lines at the end of T1, 
and the APU begins driving the AD lines ,in the middle of 


T 2. At the beginning of T 3 the CPU asserts DS. In the mid- 
dle of T 3 the CPU samples the data and negates DS. The 
second longword of data is transferred during T 4. After 
the last data transfer the CPU inserts an idle bus cycle 
(T 5 in the example) during which neither the CPU nor 
APU drive the AD lines. 
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Figure 22. Z8070·Z80,OOO Data Read Transaction 
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CPU·APU Data Write. Timing for a CPU·APU data write 
transaction is shown 'in Figure 23. This example has 
three data transfers; any number of data transfers be· 
tween 1 and 4 is possible. Timing for, the first transfer is 


identical to the CPU·APU instruction transfer transac· 
tion. A second longword of data is transferred during T 3, 
and the third longword is transferred during T 4. 
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Figure 23. Z8070·Z80,OOO Data Write Transaction 
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APU·Memory Transactions. The CPU uses status 
1010 or 1011 for the APU to read from and write to 
memory. The timing for an APU-memory read is identical 
to a CPU-memory read. The APU passively monitors the 
CPU timing on the bus, and uses the two least-significant 
address bits, the data transfer size, and the length of the 
operand from the instruction to select the bytes it needs 
from the AD line. 


The timing for an APU-memory write differs slightly from 
a CPU-memory write. Two extra bus cycles are included 
to pass the AD lines from CPU to APU after the address 
transfer and from APU back to CPU after the last data 
transfer. An example is shown (Figure 24) for a single 
APU-memory data transaction with no wait states. The 


CPU stops driving the AD lines at the end of T1, and the 
APU begins driving the AD lines in the middle of T2. OS is 
asserted in the middle of T3, one bus cycle later than for 
CPU-memory write timing. The CPU negates OS in the 
middle of T4. The CPU can insert wait states in the mid- 
dle of T4. The APU continues to drive the AD lines until 
the end of T4. After the last data transfer the CPU inserts 
an idle bus cycle (T5 in the example) during which neither 
the CPU nor APU drive the AD lines. APU-memory burst 
write transactions are similarly extended by two bus 
cycles compared with CPU-memory burst write timing. 
One cycle is inserted before· the first data transfer, and 
another cycle after the last data transfer. 
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Figure 24. Z8070·Memory Single Write Timing (Z80,000) 
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Universal Bus Transactions. The Universal interface is 
designed to accommodate a wide variety of CPUs. It can 
be tailored for data bus sizes of 8 bits, 16 bits and 32 bits. 
In transfers of data strings between the Z8070 and 
memory or the CPU, the MSB is presented first, and the 
data is left-justified, starting on pin DBo, when odd 
numbers of strings are being presented. For example, a 
Z8070/memory transaction involving the double extend- 
ed number 123456789ABCDEF02468 would be sent on a 
long-word (32 bit) bus as follows: 


first longword 12345678 
second longword 9ABCDEFO 
third longword 2468xxxx 
(where x = don't care) 


The CPU samples SIP and BSY before initiating an in- 
struction transfer to the APU. If both signals are inactive, 
the CPU asserts CS and controls the bus to transfer the 
floating-point instruction and any associated data. The 
APU recognizes that an instruction is for it when both CS 
and OS are asserted. The APU then asserts SIP to signal 
that an APU sequence is in progress.-SIP stays Low 
throughout the bus transaction portion of instruction pro- 
cessing. This prohibits the CPU from initiating another 
floating-point instruction transfer until the APU's Inter- 


face Processor is empty. If an instruction is executing in 
the Data Processor and another instruction is queued in 
the Interface Processor, the APU asserts BSY until the 
Interface Processor is empty. As with other CPU options, 
the APU asserts BSY on receiving any instruction invol- 
ving a store. Figure 25 illustrates Universal Interface bus 
transactions. 


Exception Processing 


When the Z8070 detects an exception (and the particular 
interrupt mask and master interrupt enable are enabled) 
it asserts INT. If there is an instruction in the instruction 
queue that was queued or being queued when the inter- 
rupt occurred, this queued instruction will be invalidated 
("flushed" without being executed). If the Z8070 has 
BSY asserted, (e.g., the queued instruction is a store) 
then BSY will be negated so that the store instruction 
can have the Z8070-memory transaction completed. 
This stores undefined data in memory, and the store in- 
struction is effectively invalidated. If an instruction has 
been invalidated, the RPC bit in the System Configura- 
tion register is set, indicating that the instruction was in- 
validated and must be re-executed. If an interrupt occurs 
and the queue is empty, RPC is not modified. 
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FEATURES 


c 
Full 32-bit architecture and implementation 


EJ, 4 gigabytes (billion bytes) of directly addressable 
memory 


E1 
Linear or segmented address space 


a 
Virtual memory management integrated with CPU 


[] On-chip cache memory 


I£] 
General-purpose register file with 16 32-bit registers 


[J 
9 general addressing modes 


[;J 
Numerous data types include bit, bit field, logical 
value, signed integer, and string 


m Mainframe performance 


GENERAL DESCRIPTION 


The Z80,OOO CPU is an advanced, high-end 32-bit 
microprocessor that integrates the architecture of a 
mainframe computer into a single chip. While maintain- 
ing full compatibility with Z8000 family software and 
hardware, the Z80,OOO CPU offers greater power and 
flexibility in both its architecture and interface capability. 
Operating systems and compilers are easily developed 
in the Z80,OOO CPU's high-quality environment, and the 
hardware interface provides for connection to a wide 
variety of system configurations. 


Addresses in the Z80,OOO CPU are 32 bits. This allows 
direct addressing of 4G bytes in each of four address 
spaces: System"mode data, System-mode instruction, 
Normal-mode data, and Normal-mode instruction. The 
CPU supports three modes of address representation. 
The 16-bit compact addresses are compatible with 
Z8000 nonsegmented mode. The 32-bit segmented ad- 
dresses include both 16-bit offset, which is compatible 
with Z8000 segmented mode, and 24-bit offset. In,addi- 
tion a full 32-bit linear address space is provided. 
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[J 
Extended Processing Architecture supports floating 
point operations 


[J 
Regular use of operations, addressing modes, and 
data types in instruction set 


[J 
System and Normal modes of operation with 
separate stacks 


[J 
Sophisticated interrupt and trap handling 


[J 
Software 
is 
a binary-compatible extension of 


Z8000™ software 


[J 
Hardware is compatible with other Z_BUSTM com- 
ponents 


The CPU features a general-purpose register file with 
sixteen 32-bit registers, and nine operand addressing 
modes. The various addressing modes allow encoding 
choices for compact representation or for full 32-bit ad- 
dressing. The instruction set can operate on bit, bit field, 
logical value, Signed integer, unsigned integer, address, 
string, stack, and packed decimal byte data types. 
Logical and arithmetic instructions operate on bytes (8 
bits), words (16 bits) and longwords (32 bits). The Extend- 
ed Processing Architecture (EPA) supports floating point 
operations. In addition, the instruction set is highly 
regular in combining operations, data types, and ad- 
dressing modes. High-level language compilation is sup- 
ported with instructions for procedure linkage, array in- 
dex calculation, and bounds checking. Other instruc- 
tions provide operating system functions such as system 
call and control of memory management. 


There are two main operating modes, System and Nor- 
mal, supported by separate stacks. User programs 
operate in Normal mode, while sensitive operating 
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system functions are performed in System mode. This 
protects critical parts of the operating system from user 
access. In addition, some instructions are privileged, 
and execute only in System mode. Memory management 
functions protect both system memory from user pro- 
grams, and user memory from other users. Vectored, 
nonvectored, and nonmaskable interrupts support real- 
time operating systems. 


Memory management is fully integrated with, the CPU; 
no external support circuitry is necessary. A paging ad- 
dress translation mechanism is implemented. Registers 
in the CPU point to address translation tables located in 
memory; the most recently used table entries are kept in 
a Translation Lookaside Buffer in the CPU. The CPU per- 
forms logical to physical address translation and access 
protection for each memory reference. When a logical 
memory reference causes a translation or protection 
violation, the state of the CPU is automatically restored 
to restart the instruction. 1/0 ports can be referenced 
either by. dedicated instructions or by the memory 
management m~chanism mapping logical memory ad- 
dresses to 1/0 port addresses. 


Extensive trapping facilities, such as integer overflow, 
subrange out of bounds, and subscript out of bounds, 
catch common run-time errors. Software debuggers can 
use trace and breakpoint traps. Privileged instruction 
traps and memory protection violation traps secure the 


REGISTERS 


The Z80,000 CPU is a register-oriented processor offer- 
ing sixteen 32-bit general-purpose registers, a 32-bit Pro- 
gram Counter (PC), a 16-bit Flag and Control Word 
(FCW), and nine other special-purpose registers. 


The general-purpose register file (Figure 1) con- 
tains 64 bytes. of storage. The first 16 bytes 
(RLO,RHO, ... ,RL7,RH7) can be used as accumulators for 
byte data. The first 16 words (RO,R1 , ... ,R15) can be used 
as accumulators for word data, as index registers (ex- 
cept RO), or for memory addresses in compact mode (ex- 
cept RO). Any longword register (RRO,RR2, ... ,RR30) can 
be used as an accumulator for longword data, an index 
register (except RRO), or for memory addresses in linear 
or segmented modes (except RRG). Quadword registers 
(RQO,R04, ... ,R028) can be used as accumulators for 
Multiply, Divide, and Extend Sign instructions. This 
unique register organization allows bytes and words of 
data to be manipulated conveniently while leaving most 
of the register file free to hold addresses, counters, and 
any other data. 


·Two registers are dedicated to the Stack Pointer (SP) and 
Frame Pointer (FP) used by Call, Enter, Exit, and Return 
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operating system from user programming errors or 
mischief. The Overflow Stack allows recovery from 
otherwise fatal errors. 


The CPU has full 32-bit internal address and data paths. 
Externally, 32 pins time-multiplex the address and data. 
The interface is compatible with the complete line of 
Z-BUS peripherals. The hardware interface features 
16-bit or 32-bit memory data path and programmable 
Wait states. Burst transfers and an on-chip cache for in- 
structions and data help develop high-performance 
systems. The interface supports multiprocessing con- 
figurations with interlocked memory references and two 
typ.es of bus reque$t protocols. The system designer can 
. tailor the Z80,000-based system to cost and perfor- 
mance needs. 


In summary, the Z80,000 CPU meets and surpasses the 
requirements of medium and high-end microprocessor 
systems for the 1980s. Software program development 
is easily accomplished with the CPU's sophisticated ar- 
chitecture. The highly pipelined design, on-Chip cache, 
and external interface support systems ranging from 
dedicated controllers to mainframe computers. While 
Zilog continues to develop support for the Z80,000 CPU, 
Z8000 peripherals and development software are fully 
compatible with this latest in Zilog's line of high- 
performance microprocessors. 


instructions. In compact mode, R15 is the Stack Pointer 
and R14 the Frame Pointer. In linear or segmented 
mode, RR14 is the Stack Pointer and RR12 is the Frame 
Pointer. 


{ 


RRO 
RQO 


RR2 


{ 
RR4 
RQ4 
RR6 


{ 
RR8 
RQ8 


RR10 


RQ12{ RR12 
RR14 


RQ16 {RR16 
RR18 


{ 


RR20 
RQ20 


RR22 


{ 
RR24 
RQ24 
RR26 


{ 
RR28 
RQ28 


RR30 


7 RHO o 7 RLO 


7 RH2 o 7 RL2 


7 RH4 o 7 RL4 


7 RH6 o 7 RL6 


15 
R8 


15 
R10 


15 
R12 


15 
R14 


31 


31 


31 


31 


31 


31 


31 


31 


o 7 RH1 o 7 RL1 
0 


o 7 RH3 0 7 RL3 0 
o 7 RH5 0 7 RL5 0 
o 7 RH7 0 
7 RL7 0 


o 15 
R9 
0 


o 15 
R11 
0 


o 15 
R13 
0 


o 15 
R15 
0 


0 


0 


0 


0 


0 


0 


0 


0 


RO, R1 


R2, R3 


R4, R5 


R6, R7 


Figure 1. General·Purpose Register File 
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The PC and FCW form the Program Status (Figure 2), 
which is automatically saved for traps and interrupts. 
The bits in FCW indicate operating modes, masks for 
traps and interrupts, and flags set according to the result 


of instructions. The remaining special registers are used 
for memory management, system configuration, and 
other CPU control (Figure 3). 


31 


15 
8 
7 
0 


IEJC'S/N'EPA'VIE'NVI~ US, TPI TiC, Z I S IPNI 0 I H 'IV 1 0 I 
I~ 


TRACE (T) 


TRACE PENDING (TP) 


LINEAR/SEGMENTED MODE (US) 


INTEGER OVERFLOW ENABLE (IV) 


HALF CARRY (H) 


DECIMAL-ADJUST (D) 


PARITY/OVERFLOW (PIV) 


SIGN (S) 


ZERO(Z) 


CARRY (C) 


NONVECTORED INTERRUPT ENABLE (NVIE) 


VECTORED INTERRUPT ENABLE (VIE) 


EXTENDED PROCESSOR ARCHITECTURE (EPA) 


SYSTEMINORMAL MODE (S/N) 


EXTENDED/COMPACT MODE (EJe) 


FLAG AND CONTROL WORD (FCW) 


PROGRAM COUNTER (PC) 


Figure 2. Program Status Registers 


ADDRESS SPACES 


o 


As shown in Figure 4, the CPU has three modes of ad- 
dress representation: compact, segmented, and linear. 
The mode is selected by two control bits in the Flag and 
Control Word register (see Table 1). The Extended/Com- 
pact (E/C) bit selects whether compact addresses (16 
bits) or extended addresses (32 bits) are used. For ex- 
tended addresses the Linear/Segmented (US) bit selects 
whether linear or segmented addresses are used. 


cy is due to shorter instructions in· compact mode, and 
the fact that addresses in the register file use word 
rather than longword registers. Applications requiring 
more than 64K bytes of either program or data should 
use segmented or linear modes. 


The Load Address instruction can be used to manipulate 
addresses in any mode of representation. 


In compact mode, addresses are 16 bits. Address 
calculations using compact addresses involve all 16 bits. 
Compact mode is more efficient and less program- 
consuming for applications requiring less than 64K bytes 
of program and less than64K bytes of data. This efficien- 
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Table 1. Address Representation 


Control Bits in FCW 


E/e 
US 


o 
o 
o 
1 
o 


Representation 


Compact 


Reserved 
Segmented 
Linear 
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31 


PROGRAM STATUS AREA POINTER (PSAP) 


31 


NORr.,AL STACK POINTER (NSP) 


31 
0 


SITTD I 
G I 


NLTB 
PROT 
SIZ 
TF I 


31 
0 


NDTTD I 
G I 


NLTB 
PROT 
SIZ 
TF I 


31 
0 


NITTD I 
G I 


NLTB 
PROT 
SIZ 
TF I 


31 
0 


SDTTD I 
G I 


NLTB 
PROT 
SIZ 
TF I 


TRANSLATION TABLE DESCRIPTOR REGISTERS 


31 


OVERFLOW STACK POINTER (OSP) 


HARDWARE INTERFACE CONTROL REGISTER (HICR) 


31 
o 
0 
0 
0 
00000000 
o 
0 
0 
0 
0 


SYSTEM CONFIGURATION CONTROL LONGWORD (SCCL) 


Figure 3. Speclal·Purpose Control Registers 
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15 


(A) COMPACT ADDRESSES 


31 
30 
16 15 
.0 


SEGMENT 
, 
I 
, 
, 
" 
I I I 
I 
, 
I 
OFFSET 
I 
, 
, 


(I) 64K BYTE SEGMEtlT SIZE, 


31 
30 


SEGMENT 
I 
I 
I 


2423 


I I , 


OFFSET 
I 
, 
, 
, 
, 
, 
I 
, 
, 


(II) 16M BYTE SEGr .. ENT SIZE 


(B) SEGMENTED ADDRESSES 


31 
o 
, , , , 
, 
" 
0' . 


(C) LINEAR ADDRESSES 


Figure 4. Address Representations 


In segmented mode, addresses are 32 bits. Segmented 
addresses are composed of either a 15-bit segment 
number and a 16-bit segment offset or a 7-bit segment 
number and a 24-bit segment offset. Bit 31 of the ad- 
dress selects either of the two types of segmented ad- 
dresses. Address ,calculations using segmented ad- 
dresses involve only the segment offset; the segment 
number is unaffected. In segmented mode, the address 
space allows up to 32,768 segments of 64K.byte max- 
imumsize and up to 128 segments of 16M byte max- 
imum size. Many applications benefit from the logical 
structure of segmentation by allocating individual" ob- 
jects, such as a program modUle, stack, or large data. 
structure, to separate segments: 


NORMAL AND SYSTEM MODES 


The CPU has two modes of operation, Normal and 
System, selected by the SiN bit in the Flag and Control 


, Word register. These modes impact on CPU operation in 
three areas:privilegedins!fuctions, stack painters, and 
memory manage,ment. ." 


Since the most' sensitive portions of the operating 
system usually execute in System mode, separate stack" 
pointers are used to isol~lte. the two operating modes. 


2071-004 


In linear mode, addresses are 32-bits. Address calcula- 
tions using linear addresses involve all 32 bits. In linear 
mode, the address space of 4G bytes is uniform and 
unstructured. Many applications benefit from the flex- 
ibility of linear addressing. by allocating objects at ar- 
bitrary positions in the address space. ., 


Memory ,is byte addressable by .the CPU. Th,eaddress 
used for·. multiple-byte. data. is tre' address' 6f the most 
significant byte. Multiple-byte data can be located at any 
byte address with nb alignment restrictions. 


110 ports can be addressed by either dedicated 'instruc- 
tions or by the memory management. mechanism map- 
ping logical memory addresses to I/O ports. 110 ports 
can be byte, word, or longword in size. 


Some instructions, such as those performing I/O opera- 
tions or accessing control registers, can only be. ex- 
ecuted in System mode; in addition,themernOry 
management. mechanism .' allowsacces~tosome 
memory. locations in System mode only .. Prograrns,e~~ 
ecuting,in Normal mode can re·q4estS.ervic~s from 'the 
operating system using theSysteni Calf instruction and 
trap. 
. 
. 
. 
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MEMORY MANAGEMENT 


The CPU and the operating system cooperate in 
translating logical to physical addresses and protecting 
memory for execute, read, and write accesses. The CPU 
implements a paging translation mechanism similar to 
that in most mainframe and super-minicomputers. The 
operating system creates translation tables in memory, 
then initializes pointers to the tables in control registers. 
The CPU automatically references the tables to perform 
address translation and access protection. The CPU 
enables the operating system to implement efficient vir- 
tual memory by marking pages that have been refer- 
enced or modified and by automatically recovering from 
address translation faults to allow instruction restart. 


The paging translation scheme implemented by the CPU 
divides the logical address spaces into pages and the 
physical address space into frames. The logical pages 
and physical frames are each 1 K bytes. A logical page, 
which is specified by the 22 most significant bits of the 
logical address, ,can be mapped into any physical frame, 


31 


PAGE ADDRESS 


which is specified by the 22 most significant bits of the 
physical address. The 10 least significant bits, which 
specify the byte within a page or frame, are not 
translated. For each memory reference, the CPU 
translates the logical address to the corresponding 
physical address and also tests whether access to the 
memory location is permitted. For most references the 
information needed to perform the translation is stored 
in the CPU Translation Lookaside Buffer (TLB). The TLB 
(Figu re 5) stores the translation information for the 16 
most recently referenced pages in a fully associative 
memory. Only when information to translate the page is 
missing from the TLB does the CPU reference transla- 
tion tables in memory. In the case of a TLB miss, the 
CPU translates the logical address using the procedure 
described below and the translation information is load- 
ed into the TLB entry of the le,ast recently referenced 
page. 


10 9 


TRANSLATION 
LOOKASIDE 
BUFFER 


LOGICAL PAGE 
P~~!I~:L 
ADDRESS TAGS 
ADDRESSES 


-0- 


BLE DESCRIPTOR 
LEVEL 1 
REGISTORS 
TABLE 


TA 


31 J 


LOGICAL ADDRESS I L1·NO 


PHYSICAL ADDRESS 


Figure 5. Address Translation USing the TLB 


-0- 


LEVEL 2 
TABLE 


24 23 
16 lS /10 9 


I L2·NO I P·NO I P,OFFSET 


T 


TRANSLATION 
LOOKASIDE 
BUFFER 


LOGICAL PAGE 
ADDRESS TAGS 


+ 


0 


PAGE TABLE 


31 


PHYSICAL 


FRAME 


ADDRESSES 


Figure 6. Automatic Loading of the TLB Using Tables in Memory 
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The address translation mechanism is a three-level pag- 
ing scheme. A logical address is partitioned into an 8-bit 
level-1 field (L 1-NO), an 8-bit level-2 field (L2-NO), a 6-bit 
page number field (P-NO), and a 10-bit page offset field 
(P-OFFSET). During translation, the L 1-NO, L2-NO, and 
P-NO fields are used as indexes into tables in physical 
memory. The TF field of the Segment Table Descriptor 
registers can be programmed to select!vely skip the first 
and second-level tables to reduce both the storage 
space needed for tables and the number of references 
necessary to perform translation when the information to 
translate a page is missing from the on-chip TLB. 


To load the TLB (Figure 6), the CPU selects one of four 
table descriptor registers according to the address 
space for the reference: system instruction, system 
data, normal instruction, or normal data. The table 
descriptor register points to the beginning of the level-1 
table in memory; the L 1-NO field of the logical address is 
used as an index into this table to select the level-' table 
entry. Next, the level-1 table entry points to the begin- 
ning of the level-2 table; the L2-NO field of the logical ad- 
dress is used as an index into this table to select the 
level-2 table entry. After this, the level-2 table entry 
points to the beginning of the page table in memory; the 
PAGE-NO field of the logical address is used as an index 
into this table to select the page table entry. The page 
table entry contains the physical address of the frame 
corresponding to the logiCal address. The CPU then 
loads the logical page address and physical frame ad- 
dress into the TLB. 


When bit 31 in the page table entry is " the frame is in 
physical I/O space. The CPU uses I/O status and timing 
for the reference .. Thus, the address translation process 
allows 
protected access to 
memory-mapped 
I/O 


devices. 
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TABLE FORMAT (TF) 


TABLE SIZE (SIZ) 


L..-____ PROTECTION (PROT) 


L..-_________ ~ffi t:~TE~ TABLE 


L..-____________ GROWTH DIRECTION (G) 
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00 
THREE LEVELS 


Table Format 
(TF) 


01 
SKIP LEVEL 2 TABLES 
10 SKIP LEVEL 1 TABLES 
11 
SKIP LEVEL 1 AND LEVEL 2 TABLES 


TADL[; SIZE 
VALID TABLE ENTRIES 
(SIZ) 
0=0 
0=1 


00 
OTO 63 
o TO 255 


01 
o TO 127 
64 TO 255 


10 
OTO 191 
. 128 TO 255 


11 
o TO 255 
192 TO 255 


Figure 7. Translation Table Descriptor 


3 
2 
1 
0 


VALID (V) 


'---- TABLE SIZE (SIZ) 


L....-____ PROTECTION (PROT) 


1...-_________ ~:~ t:~i~ TABLE 


L..-_____________ GROWTH DIRECTION (G) 


LEVEL 1 TABLE EUTRY 


31 
1 
0 


VALID (V) 


L....-____ PROTECTION (PROT) 


1...-_________ NEXT LEVEL TABLE 


LEVEL 2 TABLE EUTRY 
BASE (NLTB) 


Figures 7 and 8 show the translation and table entry for- 
31 
mats. 
r-r-------.,.--r---r..,....,.....,..... 


Access protection information (Table 2) is encoded in the 
4-bit PROT field contained in the Translation Table 
Descriptor, level-' table entry, level-2 table entry, or 
page table entry. During the translation process, a PROT 
field is encountered at each level. The first PROT field 
with value other than' 000 is selected; the other PROT 
fields are ignored. The protection code specifies the 
types of access (execute, read, and write) permitted in 
Normal and System modes. 
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REFERENCED (R) 


VALID (V) 


MODIFIED (M) 


1...--__ NONCACHEABLE (NC) 


'------ PROTECTION (PROT) 
L....-______ UNUSED 


L..-_________ FRAME ADDRESS (FA) 


L....-_____________ 1/0 


PAGE TABLE EUTRY 


Figure 8. Table Entry Formats 
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Table 2. Protection Field Encoding 


Encoding 
System 


0000 
0001 
0010 
0011 


0100 
0101 
0110 
0111 


1000 
1001 
.1010 
1011 


1100 
1101 
1110 
1111 


NA-no access is permitted 
R-read access is permitted 
W-write access is permitted 
E-execute access is permitted 


NA 
RE 
RE 
RE 
E 
E 
R 
R 


Note 
RW 
RW 
RW 


RWE 
RWE 
RWE 
RWE 


Normal 


NA 
NA 
E 
RE 


NA 
E 
NA 
R 


Note 
NA 
R 
RW 


NA 
E 
RE 
RWE 


Note-use the protection field of the next level translation table or NA 
(for page tables) 


There are several optional features that allow the 
number of levels and the size of tables to be reduced. 
When memory address spaces are not separated, two or 
more of the· translation table descriptor registers can be 
loaded with the same value so that tables are held in 


EXCEPTIONS 


The CPU supports four types of exceptions: Reset, Bus 
Error, interrupts, and traps. A reset exception occurs 
when the RESET line is activated; this causes the CPU to 
be reset to an initialized state. A bus error exception oc- 
curs when externalrhardware indicates an error on a bus 
transaction. An interrupt is an asynchronous event that 
typically occurs when a peripheral device needs atten- 
tion. A trap is a synchronous event that occurs when a 
particular condition is detected during execution of an in- 
struction. 
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common. The table descriptor register can specify that 
either or both of the level-1 and level-2 tables should be 
skipped during the translation process. Level-1 tables 
can be skipped when a 24-bit logical address space is 
sufficient, both level-1 and level-2 segment tables can be 
skipped for compact addresses, and level-2 tables can 
be skipped for compatibility with Z8000 segmented ad- 
dresses. The table size can be reduced by allocating 
only 256, 512, or 768 bytes for the tables; the remaining 
table entries are assumed invalid. The tables can be 
allocated efficiently for downward growing stacks by set- 
ting the G bit of the translation table descriptor or level-1 
table entry. 


During execL:tion of an instruction, if an invalid transla- 
tion table entry is encountered or a protection violation is 
detected, the CPU traps to the operating system. The 
CPU automatically saves the state of registers and 
memory so the instruction can simply be restarted. 


Several instructions are provided to help the operating 
system control memory management. The Purge TLB in- 
structions are used to purge the Translation Lookaside 
Buffer of a single entry, Normal mode entries, or all en- 
(tries. The Load Physical Address instructions translate 
logical addresses into physical addresses, and set the 
flags to verify access permission for system call 
parameters. The instructions, Load Normal Data and 
Load Normal Instruction allow System mode programs 
to reference Normal memory spaces. 


The memory management mechanism can be selective- 
ly enabled for normal and system space references by 
using the SX and NX bits of the System Configuration 
Control Longword register. 


In responding to a reset exception, the CPU fetches the 
program status (FCW and PC) from physical address 2. 
In responding to other exceptions, the CPU pushes the 
old program status onto the system stack along with in- 
formation specific to the type of exception. The CPU 
then fetches a new program status from the table 
designated by the Program Status Area Pointer control 
register. 


During exception processing, the mode of address 
representation for the system Stack Pointer and Pro- 
gram Status Area Pointer is either linear or segmented, 
selected by the XLIS bit in the System Contfguration Con- 
trol Longword register. Three types of interrupts are sup- 
ported: vectored, nonvectored, and nonmaskable. The 
vectored and nonvectored interrupts have mask bits in 
the FCW. All interrupts read an identifier word from the 
bus during an Interrupt Acknowledge transaction and 
save the word on the system stack. Vectored interrupts 
use the lower byte of this word to select a unique PC 
value from the Program Status Area. 


The CPU recognizes twelve trap conditions. 


o 
Extended Instruction Trap occurs when an Extended 
Processing Architecture instruction is executed and 
the EPA bit in the FCW is clear. 
o 
Privileged Instruction Trap occurs when an attempt 
is made to execute a privileged instruction in Normal 
mode. 
o 
System Call Trap occurs when the System Call in- 
struction is executed to request service from the 
operating system. 


o 
Address Translation Trap occurs when an address 
translation or access protection violation is 
detected. 


o 
Reserved Instruction Trap occurs when an attempt 
is made to execute 'an instruction' with a reserved bit 
pattern. 


o 
Odd PC Trap occurs when an odd-byte address is 
loaded into the PC. 


o Trace Trap occurs after execution of an instruction 


ADDRESSING MODES 


The CPU locates operands (the data manipulated by in- 
structions) in registers, memory, I/O ports, or in the in- 
struction. The location of an operand is specified by one 
of nine addressing modes (Figure 9): Register (R), Im- 
mediate (1M), Indirect Register (IR), Direct Address (DA), 
Index (X), Base Address (BA), Base Index (BX), Relative 
Address (RA), and Relative Index (RX). Most operations 
can be used with any addressing mode; however, some 
operations are restricted. Instruction encoding provides 


when tracing is enabled by setting the T bit in the 
FCW. 
o 
Breakpoint Trap occurs when the Breakpoint instruc- 
tion is executed, usually to invoke a debugging or 
monitoring program. 


o 
Conditional Trap occurs when the Conditional Trap 
instruction is executed and the specified condition 
code is satisfied. This trap can allow detection of 
user-defined exceptions. 


o 
Integer Overflow Trap occurs when overflow is 
detected during execution of an integer arithmetic 
instruction and the IV bit in the FCW is set. 


o 
Bounds Check Trap occurswhen the Check instruc- 
tion is executed and the source operand is out of 
bounds. 


,0 Subscript Error Trap occurs when the Index instruc- 


tion is executed and the subscript operand is out of 
bounds. 


In descending order, the priority of exceptions is: reset, 
bus error, trap (other than trace), nonmaskable interrupt, 
vectored interrupt, and nonvectored interrupt. Trace 
Trap uses two control bits, T and TP, so that when trac- 
ing is enabled, exactly one trace trap occurs after each 
instruction is executed. 


When an address translation trap occurs for the system 
stack, the CPU cannot save the program status and 
other exception information on the system stack. The 
system can still recover from this otherwise fatal error . 
because the CPU saves the information on the Overflow 
Stack designated in physical memory by the Overflow 
Stack Pointer control register. 


compact representation for the most frequently used ad- 
dressing modes. 


The term Extended Addressing Modes (EAM) refers to 
the following addressing modes that require one or more 
extra words to be added to the opcode. 
o 
In compact mode: DA and X (X is equivalent to BA) 
o 
In linear or segmented modes: DA, X, BA, BX, RA, 
and RX 
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Addressing Mode 
Operand Addressing 


In tho Instruction 
In a Register 
In Memory 


R 


Register 
1 
REGISTER ADDRESS H 
OPERAND 1 


1M 


Immediate 
1 OPERAND 


*IR 


Indirect 
~GISTER ADDRESS H 
ADDRESS 
Register 
-I OPERAND 


DA 


Direct 
ADDRESS 
-I 


OPERAND 
Address 


*X 


REGISTER ADDRESS 
Index 
BASE ADDRESS 


RA 


PC VALUE ~I 


Relative 
Address 


DISPLACEMENT 
OPERAND 


*BA 


Base 


REGISTER ADDRESS 


Address 
DISPLACEMENT 
OPERAND 


*BX 


Base 
Index 
REGISTER ADDRESS 


REGISTER ADDRESS 
OPERAND] 


DISPLACEMENT 


*RX 


1='0--1 


Relativo 


PC VALUE 


Index 


INDEX 
OPERAND 


*RO and RRO cannot bo used for Indirect. Baso. or Index registors 


Figuro 9. Addressing Modes 
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Operand Value 


Tho content of the 
register 


In tho Instruction 


The content of the 
location whoso 
address Is In the 
reglstor 


The content of the 
location whose address 
Is In the Instruction 


The content of the 
location whose 
address is the address 
In the Instruction. plus 
the content of tho 
Index register 


The contont of the 
location whose 
address Is tho address 
In tho Instructlon. plus 
tho content of the 
Index register 


The contont of tho 
location whose 
address Is the content 
of the Baso reglstor. 
plus the displacGmGnt 
In the Instruction 


The content of the 
location whoso 
addross Is the content 
of the Base register. 
plus the content of 
the Indox register. 
plus the displacement 
In the Instruction 


The content of the 
location whoso 
addreso Is tho content 
of the Program 
Counter. plun the con- 
tont of the Index 
reglotor. plus tho 
dlsplacoment In the 
Instructlon. 
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DATA TYPES 


The CPU supports operations on the following data 
types. 


EJ 
Bit 


EI 
Bit field-1 to 32 contiguous bits within a longword 


rEI 
Signed integer-byte, word, longword, and quad- 
word 


m Unsigned integer-byte, word, longword, and quad- 


word 


FLAGS AND CONDITION CODES 


Arithmetic, logical, and many other instructions affect 
the six flag bits (C, Z, S, PN, D, and H) in the FCW to pro- 
vide information about an operation's result. Generally, 
C indicates carry or borrow from the result, Z indicates 
the result is zero, S indicates whether the result is 


c 
Logical value-byte, word, and longword 


[] Address 


[] 
Packed BCD integer-byte 


[] Stack-word and longword 


[] String-dynamic length byte, word, and longword 


negative or positive, and PN indicates parity or overflow. 
D and H are used for decimal arithmetic. 


Jump, Test Condition Code, and several other instruc- 
tions test the state of the flags. The conditions that can 
be tested are shown in Table 3. 


Table 3. Flags and Condition Codes 


Code 
Meaning 
Flag Setting 
Binary 


F 
Always false 
0000 


T 
Always true 
1000 
Z 
Zero 
Z = 1 
0110 
NZ 
Not zero 
Z=O 
1110 
C 
Carry 
C=1 
0111 


NC 
No carry 
C=O 
1111 


PL 
Plus 
5=0 
1101 
MI 
Minus 
5 = 1 
0101 


NE 
Not equal 
Z=O 
1110 


EQ 
Equal 
Z = 1 
0110 
OV 
Overflow 
V = 1 
0100 
NOV ' No overflow 
V=O 
1100 


PE 
Parity even 
P = 1 
0100 


PO 
Parity odd 
P=O 
1100 


GE 
Greater than or equal 
(5 XOR V) = 0 
1001 


LT 
Less than 
(5 XOR V) = 1 
0001 


GT 
Greater than 
(Z OR (5 XOR V») = 0 
1010 


LE 
Less than or equal 
(Z OR (5 XOR V») = 1 
0010 


UGE 
Unsigned greater than or equal 
C=O 
1111 
ULT 
Unsigned less than 
C = 1 
0111 


UGT 
Unsigned greater than 
((C = 0) AN D (Z = 0) = 1 
1011 


ULE 
Unsigned less than or equal 
(C OR Z) = 1 
0011 


Some of the condition codes correspond to identical flag settings: i.e .• Z-EQ. NZ-NE. NC-UGE. PE-OV, PO-NOV. 


701 


INSTRUCTION SeT SUMMARY 


The CPU provides 11 types of in~tructions: 


• 
Load and Exchange 


• 
Arithmetic 


• 
Logical 


• 
Program Control 


• 
Bit Mcmipulation 


• 
Rotate and Shift 


Load and Exchange 


Mnemonic 


CLR 
CLRB 
CLRL 


CVTBW 
CVTBL 
CVTWB 
CVTWL 
CVTLB 
CVTLW 


CVTUBW 
CVTUBL 
. CVTUWB 
CVTUWL 
CVTULB 
CVTULW 


EX 
EXB 
EXC 


LO 
LOB 
LDL 


LPA 


LOA~ 


.. LOK 


LPKL 


Operands 


dst 


dst,src 


dst,src 


dst,src 


dst,src 


dst,src . 


dst;src 


dst,n 


~c~mpact rTl~~ allows BX with ~a disPlaceme~t for EAM. 
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• 
Block Transfer and String Manipulation 


• 
Input/Output 


• 
CPU Control 


• 
Bit Field 


• 
Extended Instructions 


Instructions are encoded in one or more words, located 
in memory at even addresses. 


Addressing Modes 
Operation 


dst: R,IR,EAM 


dst: R 
src: R,IR,EAM 


or 
dst: IR,EAM 
src: R 


dst: R 
src:R,IR,EAM 


or 
dst: IR,EAM 
src:R 


dst: R 
src: R,IR,EAM 


dst: R 
src: R,IM,IR,EAM* 


or 
dst: IR,EAM* 
src: R,IM 


dst: R 
. sra: EAM* 


dst: R 
src.:RA 


dstR 
n: 1M· 


Clear 


dst - 
0 


Convert 


dst - 
convert (src) 


Convert Unsigned 


dst - 
convert (src) 


Exchange 


dst - 
src 


Load 


dst - 
src 


Load Address 


dst.· - 
Address (src) 


. Load Address Relative 


dst - 
Address (src) 


Load Constant 


dst -n . 
(n = 0 .. 15) 


Load and Exchange (Continued) 


Mnemonic 
Operands 
Addressing Modes 
Operation 


LDM 
dst,src,n 
dst: R 
Load Multiple 


src: IM,IR,EAM 
dst - 
src (n words) 
n: 1M 


or 
dst: IR,EAM 
src: R 
n: 1M 


LDML 
mask,src 
mask: 1M 
Load Multiple Long 
src: IM;IR,EAM 
dst (register mask) - 
src 
or 
or 
dst,mask 
dst: IR,EAM 
or 


src: 1M 
dst - 
src (register mask) 


N 
CO 


LDR 
dst,src 
dst: R 
Load Relative 
p 


LDRB 
src: RA 
0 


dst - 
src 
g 
LDRL 
or 
dst: RA 
6 ... 


src: R 
c:I 


POP 
dst,src 
dst: R,IR,EAM 
Pop 


POPL 
src: IR 
dst - 
src 
Autoincrement src address 


PUSH 
. dst,src 
dst: IR 
Push 


PUSHL 
src: R,IM,IR,EAM 
Autodecrement dst address 
dst - 
src 


Arithmetic 


Mnemonic 
Operands 
Addressing Modes 
Operation 


ADC 
dst,src 
dst:' R 
Add with Carry 
ADCB 
src: R 
dst - 
dst + src + C 
ADCL 


ADD 
dst,src 
dst: R 
Add 
ADDB 
src: R,IM,IR,EAM 
dst - 
dst + src 
ADDL 


CHK 
dst,src 
. dst: R 
Check 
CHKB 
src: IM,IR,EAM 
compare dst with src bounds 
CHKL 
if out of bounds then trap 


CP 
dst,src 
dst: R 
Compare 
CPB 
src: R,IM,IR,EAM 
dst - src 
CPL 
or 
dst: IR,EAM 
src: 1M 


DAB 
dst 
dst: R 
Decimal Adjust 


DEC 
dst,n 
dst: R,IR,EAM 
Decrement 
DECB 
n: 1M 
dst - 
dst - 
n 
DECL 
(n = 1..16) 
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Arithmetic (Continued) 


Mnemonic 
Operands 
Addressing Modes 
Operation 


DECI 
dst,n 
dst: IR,EAM 
Decrement Interlocked 
DECIB 
n: 1M 
dst - 
dst - 
n 
(n = 1..16) 


DIV 
dst,src 
dst: R 
Divide 


DIVL 
src: R,IM,IR,EAM 
dst (low) - 
dst DIV src 
dst (high) - 
dst REM src 


DIVU 
dst,src 
dst: R 
Divide Unsigned 


DIVUL 
src: R,IM,IR,EAM 
dst (low) - 
dst DIV src 
dst (high) - 
dst REM src 


EXTS 
dst 
dst: R 
Extend Sign 
EXTSB 
dst - 
sign_extend (dst (low)) 
EXTSL 


/: ,. 
INC 
dst,n 
dst: R,IR,EAM 
Increment 
\\ ~ 
\-,' 
INCB 
n: 1M 
,.~~"\ 
~ .. 
dst - 
dsl + n 
INCL 
(n = 1 .. 16) 


INCI 
dst,n 
dst: IR,EAM 
Increment Interlocked 
INCIB 
n: 1M 
dst - 
dst + n 
(n = 1..16) 


INDEX 
dst,sub,src 
dst: R 
Index 
INDEXL 
sub: R 
calculate array index: 
src: IM,IR,EAM 
check, scale, and accumulate 


MULT 
dst,src 
dst: R 
Multiply 
MULTL 
src: R,IM,IR,EAM 
dst - 
dst (low) * src 


MULT,U 
dst,src 
dst: R 
. Multiply Unsigned 
MULTUL 
src: R,IM,IR,EAM 
dst - 
dst (low) * src 


NEG 
dst 
dst: R,IR,EAM . 
Negate 
NEGB 
dst - 
dst 
NEGL 


SBC 
dst,src 
dst: R 
Subtract with Carry 


SBCB 
src: R 
dst - 
dst - 
src - 
C 
SBCL 


SUB 
dst,src 
dst: R 
Subtract 


SUBB 
src: R,IM,IR,EAM 
dst - 
dst ~ src 
SUBL 


TESTA 
dst 
dst: R,IR,EAM 
Test Arithmetic 
TESTAB 
dst - 
0 
TESTAL 
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Logical 


Mnemonic 
Operands 
Addressing Modes 
Operation 


AND 
dst,sre 
dst: R. 
And 
ANDB 
sre: R,IM,IR,EAM 
dst - 
dst AND sre 
ANDl 


COM 
dst 
dst: R,IR,EAM 
Complement 
COMB 
dst - 
NOT dst 
COMl 


OR 
dst,sre 
dst: R 
Or 
ORB 
sre: R.,IM,IR,EAM 
dst - 
dst OR sre 
ORl 


TCC 
ee,dst 
dst: R 
Test Condition Code 
N 


TCCB 
if ee then 


~ 
0 
TCCl 
... 
dst - 
dst OR 1 
§ 


TEST 
dst 
dst: R,IR,EAM 
Test 
8 


TESTB 
dst OR 0 
-a 


TESTl 
CI 


XOR 
dst,sre 
dst: R 
Xor 


XORB 
sre: R,IM,IR,EAM 
dst - 
dst XOR sre 
XORl 


Program Control 


Mnemonic 
Operands 
Addressing Modes 
Operation 


BRKPT 
Breakpoint 


(breakpoint trap) 
Push PS onto System Stack 
Push instruction 
PS - 
Breakpoint PS 


CAll 
dst 
dst: IR,EAM 
Call 


Autodeerement SP 
@SP - 
PC 


PC - 
Address (dst) 


CAlR 
dst 
dst: RA 
Call Relative 


Autodeerement SP 
@SP - 
PC 


PC - 
Address (dst) 


DJNZ 
ent,dst 
ent: R 
Decrement and Jump If Not Zero 
DBJNZ 
dst: RA 
ent - 
ent - 
1 
DlJNZ 
if ent * 0 then 


PC - 
Address (dst) 
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Program Con~rol (Continued) 


Mnemonic 
Operands 
Addressing Modes 
Operation 


ENTER 
mask,siz 
mask:'IM 
Enter Procedure 
siz: 1M 
Push registers (mask) 
Push FP 
Push mask 
Push 0 (exception handler) 
FP - 
SP + siz 
update integer overflow mask 


EXIT 
Exit Procedure 


SP - 
FP 
Pope'xception handler 
POpl mask 
Pop FP 
Pop registers (mask) 
restore integer overflow mask 


JP 
cC,dst 
dst: IR,EAM 
Jump 


if cc then 


PC - 
Address (dst) 


JR 
cC,dst 
dst: RA 
Jump Relative 


if cc'then 


PC - 
Address (dst) 


RET 
cc 
Return 


if cc then 


PC - 
@SP 


Autoincrement SP 


SC 
src 
src: 1M 
System Call 


(system call trap) 
Push PS onto System Stack 
Push instruction 
PS - 
System Call PS 


TRAP 
cC,src, 
src: 1M 
Trap Conditional 


if cc then 
(condition trap) 
Push PS onto System Stack 
Push instruction 
PS - 
Conditional Trap PS 
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Bit Manipulation 


Mnemonic 
Operands 
Addressing Modes 
Operation 


BIT 
dst,src 
dst: R,IR,EAM 
Test Bit 


BITB 
src: 1M 
Z - 
NOT dst (src) 
BITL 
or 
dst: R 
src: R 


RES 
dst,src 
dst: R,IR,EAM 
Reset Bit 


RESB 
src: 1M 
dst (src) - 
0 
RESL 
or 
dst: R 
src: R 


SET 
dst,src 
dst: R,IR,EAM 
Set Bit 
N 
r 


SETB 
src: 1M 
dst (src) - 
1 


Q 
SETL 
or 
0 


dst: R 
g 


src: R 
0 
fI-' 
TSET 
dst 
dst: R,IR,EAM 
Test and Set 
.. 
a 
TSETB 
s - 
dst (MSB) 
TSETL 
dst - 
-1 


Rotate and Shift 


Mnemonic 
Operands 
Addressing Modes 
Operation 


RL 
dst,n 
dst: R 
Rotate Left 
RLB 
n: 1M 
dst - 
dst rotate left 
RLL 
n.bits 
(n = 1 or 2) 


RLC 
dst,n 
dst: R 
Rotate Left through Carry 
RLCB 
n: 1M 
dst,C - 
dst,C rotate left 
RLCL 
n bits 
(n = 1 or 2) 


RLDB 
Iink,dst 
link: R 
Rotate Left Digit 
dst: R 
dst,link(0:3) - 
dst,link (0:3) 


rotate left 1 digit 


RR 
dst,n 
dst: R 
Rotate Right 
RRB 
n: 1M 
dst - 
dst rotate right 
RRL 
n bits 
(n = 1 or 2) 


RRC 
dst,n 
dst: R 
Rotate Right through Carry 
RRCB 
n: 1M 
dst,C - 
dst,C rotate right 
RRCL 
n bits 
(n = 1 or 2) 
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Roiate and Shift (Continued) 


Mnemonic 
Operands 
Addressing Modes 
. Operation 


RRDB 
link,dst 
link: R 
Rotate Right Digit 
dst: R 
dst,link (0:3) - 
dst,link (0:3) 
rotate right 1 digit 


SOA 
dst,src 
dst: R 
Shift Dynamic Arithmetic 


SDAB 
src: R 
dst - 
dst arithmetic shift 
SDAL 
src bits· 


SOL 
dst,src 
dst: R 
Shift Dynamic Logical 


SDLB 
src: R 
dst - 
dst logical shift 
SDLL 
src bits 


SLA 
dst,n 
dst: R 
Shift Left Arithmetic 


SLAB 
n: 1M 
dst - 
dst arithmetic shift 
SLAL 
left n bits 


SLL 
dst,n 
dst: R 
Shift Left Logical 


SLLB 
n: 1M 
dst - 
dst logical shift 
SLLL 
left n bits 


SRA 
dst,n 
dst: R 
Shift Right Arithmetic 


SRAB 
n: 1M 
dst - 
dst arithmetic shift 
SRAL 
right n bits 


SRL 
dst,n 
dst: R 
Shift Right Logical 


SRLB 
n: 1M 
dst - 
dst logical shift . 
SRLL 
right n bits 


Block Transfer and String Manipulation 


Mnemonic 
Operands 
Addressing Modes 
Operation 


CPO 
dst,src, 
dst: R 
Compare and Decrement 


CPOB 
cnt,cc 
src: IR 
dst - 
src 
CPDL 
cnt: R 
Autodecrement src address 
cnt - 
cnt - 
1 


CPOR 
dst,src, 
dst: R 
Compare, Decrement, and Repeat 


CPDRB 
cnt,cc 
src: IR 
Repeat 
CPDRL 
cnt: R 
dst - 
scr 
Autodecrement src address 
cnt - 
cnt - 
1 


Until cc is true or cnt = 0 


CPI 
dst,src, 
dst: RO 
Compare and Increment 
CPIB 
cnt,cc 
src: IR 
dst - 
src 
CPIL 
cnt: R 
Autoincrement src address 
cnt - 
cnt - 
1 
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Blocle Transfer and String Manipulation (Continued) 


Mnemonic 
Oporands 
Addressing Modes 
Operation 


CPIR 
dst,sre, 
dst: R 
Compare, Increment, and Repeat 


CPIRB 
ent,ee 
sre: IR 
Repeat 
CPIRL 
ent: R 
dst - 
src 
Autoinerement sre address 
ent - 
ent - 
1 
Unit ee is true or ent =' 0 


CPSD 
dst,sre, 
dst: IR 
Compare String and Decrement 


CPSDB 
ent,ee 
sre: IR 
dst - 
sre 
CPSDL 
ent: R 
Autodeerement dst and sre addresses 
ent - 
ent - 
1 


N 
r 
CPSDR 
dst,sre, 
dst: IR 
Compare String, Decrement, Repeat 
J 
CPSDRB 
ent,ee 
sre: IR 
Repeat 
CPSDRL 
ent: R 
0 


dst - 
src 
8 
Autodeerement dst and sre 
" 
addresses 
:= 
ent - 
ent - 
1 


!Jntil ee is true or ent=O 


CPSI 
dst,sre, 
dst: IR 
Compare String and Increment 
CPSIB 
ent,ee 
sre: SR 
dst - 
sre 
CPSIL 
ent: R 
Autoinerement dst and sre addresses 
ent - 
ent - 
1 


CPSIR 
dst,sre, 
dst: IR 
Compare String, Increment, Repeat 


CPSIRS 
ent,ee 
sre: IR 
Repeat 
CPSIRL 
ent: R 
dst - 
sre 
Autoinerement dst and sre 
addresses 
ent - 
ent - 
1 


Until ee is true or ent = 0 


LDD 
dst,sre,ent . 
dst: IR 
Load and Decrement 
LDDB 
sre: IR 
dst - 
sre 
LDDL 
ent: R 
Autodeerement dst and sre addresses 
ent - 
ent - 
1 


LDDR 
dst,sre,ent 
dst: IR 
Load, Decrement, and Repeat 
LDDRB 
sre: IR 
Repeat 
LDDRL 
ent: R 
dst - 
sre 
Autodeerement dst and sre 
addresses 
ent - 
ent - 
1 


Unitl ent= 0 


LDI 
dst,sre,ent 
dst: IR 
Load and Increment 
LOIB 
sre: IR 
dst - 
sre 
LOlL 
ent: R 
Autoinerement dst and sre addresses 
ent - 
ent - 
1 
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· Block Transfer and String Manipulation (Continued) 


Mnemonic 
Operands 
Addressing Modes 
Operation 


LDIR 
dst,src,cnt 
d~t: IR 
Load, Increment, and Repeat 


LDIRB 
src: IR 
Repeat 
LDIRL 
cnt: R 
dst - 
src 
Autoincrement dst and src 
addresses 
cnt - 
cnt - 
1 
Until cnt= 0 


TRDB 
dst,src,cnt 
dst: IR 
Translate and Decrement 
src: IR 
dst - 
src [dst] 
cnt: R 
Autodecrement dst address 
cnt - 
cnt - 
1 


TRDRB 
dst,src,cnt 
dst: IR 
Translate, Decrement, and Repeat 
src: IR 
Repeat 
cnt: R 
dst - 
src [dst] 
Autodecrement dst address 
cnt - 
cnt - 
1 


Until cnt= 0 


TRIB 
dst,src,cnt 
dst: IR 
Translate and Increment 


src: IR 
dst - 
src [dst] 
cnt: R 
Autoincrement dst address 
cnt - 
cnt - 
1 


TRIRB 
dst,src,cnt 
dst: IR 
Translate, Increment, and Repeat 
src: IR 
Repeat 
cnt: R 
dst - 
src [dst] 
Autoincrement dst address 
cnt - 
cnt - 
1 


Until'cnt = 0 


TRTDB 
src1,src2, 
src1: IR 
Translate, Test, and Decrement 
cnt 
src2: IR 
RH 1 - 
src2 [src1] 
cnt: R 
Autodecrement src1 address 
cnt - 
cnt - 
1 


TRTDRB 
src1,src2, 
src1: IR 
Translate, Test, Decrement, Repeat 
cnt 
src2: IR 
Repeat 
cnt: R 
RH1 - 
src2 [src1] 
Autodecrement src1 address 
cnt - 
cnt - 
1 


Until RH1 *0 or cnt=O 


TRTIB 
src1,src2, 
src1 :IR 
Translate, Test, and Increment 


cnt 
src2: IR 
RH 1 - 
src2 [src1] 
cnt: R 
Autoincrement src1 address 
cnt - 
cnt - 
1 
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Blo~f( Transfer and String Manipulation (Con~inued) 


Mnemonic 
Operands 
Addressing Modes 
Operation 


TRTIRB 
sre1,sre2, 
sre1: IR 
Translate, Test, Increment, Repeat 
ent 
sre2: IR 
Repeat 
ent: R 
RH1 - 
'sre2 [sre1] 
Autoinerement sre1 . address 
ent - 
ent - 
1 


Until RH1 *0 or ent=O 


Input/Output 


Mnemonic 
Operands 
Addressing Modes 
Operation 


00 
IN* 
dst,sre 
dst: R 
Input 
eo 
INB* 
sre: IR,DA 
Q 


dst - 
sre 
.. 


INl* 
~ 
C:) 
t;) 
IND* 
dst,sre,ent 
dst: IR 
Input and Decrement 
6 
t{J 
INDB* 
sre: IR 
dst - 
sre 
= 
INDl* 
ent: R 
Autodeerement dst address 
ent - 
ent - 
1 


INDR* 
dst,sre,ent 
dst: IR 
Input, Decrement, and Repeat 


INDRB* 
sre: IR 
Repeat 
INDRl* 
ent: R 
dst - 
sre 
Autodeerement dst address 
ent - 
ent'- 1 


Until ent=O 


INI* 
dst,sre,ent 
dst: IR 
Input and Increment 
INIB* 
sre: IR 
dst - 
sre 
INll* 
ent: R 
Autoinerement dst address 
ent - 
ent - 
1 


INIR* 
dst,sre,ent 
dst: IR 
Input, Increment, and Repeat 


INIRB* 
sre: IR 
Repeat 
INIRl* 
ent: R 
dst - 
sre 
Autoinerement dst address 
ent - 
ent - 
1 


Until ent =0 


OTDR* 
dst,sre,ent 
dst: IR 
Output, Decrement, and R'epeat 
OTDRB* 
sre: IR 
Repeat 
OTDRl* 
ent: R 
dst - 
sre 
Autodeerement sre address 
ent - 
ent - 
1 


Until ent=O 


OTIR* 
dst,sre,ent 
dst: IR 
Output, Increment, and Repeat 


OTIRB* 
sre: IR 
Repeat 
OTIRl * 
ent: R 
dst - 
sre 
Autoinerement sre address 
ent - 
ent - 
1 


Until ent= 0 
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Input/Output (Continued) 


Mnemonic 
Operands 
Addressing Modes 
Operation 


OUT* 
dst,src 
dst: IR,DA 
Output 
OUTB* 
src: R 
dst - 
src 
OUTL* 


OUTD* 
dst,src,cnt 
dst: IR 
Output and Decrement 


OUTDB* 
src: IR 
dst - 
src 
OUTDL* 
cnt: R 
Autodecrement src address 
cnt - 
cnt - 
1 


OUTI* 
dst,src,cnt 
pst: IR 
Output and Increment 
OUTIB* 
src: IR 
dst - 
src 
OUTIL* 
cnt: R 
Autoincrement src address 
cnt - 
cnt - 
1 


CPU Control 


Mnemonic 
Operands 
Addressing Modes 
Operation 


COMFLG 
flags 
flags: 1M 
Complement Flag 


DI* 
ints 
ints: 1M 
Disable Interrupt 


EI* 
ints 
ints: 1M 
Enable Interrupt 


HALT* 
Halt 


IRET* 
Interrupt Return 


PS - 
@SP 
Autoincrement SP 


LDCTL* 
dst,src 
dst: CTLR 
Load Control Register 
src: R 
or 
dst - 
src 


dst: R 


LDCTLB 
dst,src 
dst: FLGR 
Load Flag Byte Register 
src: R 
dst - 
src 
or 
dst: R 
src: FLGR 


LDCTLL* 
dst,src 
dst: CTLRL 
Load Control Register Long 
src: R 
or 
dst - 
src 


dst: R 
src: CTLRL 


LDND* 
dst,src 
dst: R 
Load Normal Data Address Space 


LDNDB* 
src: IR,EAM 
dst - 
src 
LDNDL* 
or 
dst: IR,EAM 
src: R 


'Privileged instruction 
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CPU Con~rol (Con~inued) 


Mnemonic 
Operands 
Addressing Modes 
Operation 


LDNI* 
dst,src 
dst: R 
Load Normal Instruction Address 


LONIS* 
src: IR,EAM 
Space 
LONIL* 
or 
dst - 
src 
dst: IR,EAM 
src: R 


LOPS* 
src 
src: IR,EAM 
Load Program Status 


PS - 
src 


LONO* 
dst,src 
dst: R 
Load Physical Address 


LONI* 
src: IR,EAM 
dst - 
PhysicalJddress (src) 
LOSO* 
E.\1 
LOSI* 
CO e 


NOP 
No Operation 
~ 


PCACHE* 
Purge Cache 
6 
£U 


PTLB* 
Purge TLB 
Cl 


PTLBENO* 
src 
src: IR,EAM 
Purge TLB Entry 


PTLBENI 
PTLBESO* 
PTLBESI* 


PTLBN* 
Purge TLB Normal 


RESFLG 
flag 
flag: 1M 
Reset Flag 


SETFLG 
flag 
flag: 1M 
Set Flag 


Bit Field 


Mnemonic 
Operands 
Addressing Modes 
Operation 


EXTR 
dst,src, 
dst: R 
Extract Field 


pos,siz 
src: R,IR,EAM 
dst - 
src (pos,siz) 
pos: IM,R 
siz: IM,R 


EXTRU 
dst,src, 
dst: R 
Extract Unsigned Field 


pos,siz 
src: R,IR,EAM 
dst - 
src (pos,siz) 
pos: IM,R 
siz: IM,R 


INSRT 
dst,src, 
dst: R,IR,EAM 
Insert Field 


pos,siz 
src: R 
dst - 
(pos,siz) - 
src 
pos: IM,R 
siz: IM,R 


• Privileged instruction. 
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EXTENDED INSTRUCTIONS 


The Z80,OOO CPU .supports extended instructions 
through the Zilog Extended Processing Architecture 
(EPA). The EPA facility allows the operations defined in 
the Z80,OOO architecture to be extended' by software or 
hardware. In particular, floating-point operations are 
supported by the Z8070 Arithmetic Processing Unit 
(APU) or by a software package that emulates the APU. 


Up to four Extended Processing Units (EPUs) can be in- 
cluded in a Z80,OOO CPU system. The CPU and EPU 
cooperate in execution· of EPA instructions. When the 
CPU encounters an EPA instruction, the instruction is 
transmitted across the external bus to the appropriate 
EPU. The CPU then performs transactions on the exter- 
nal bus to transfer data between the EPU and memory or 
the EPU and CPU. Transfers between the EPU and CPU 
can involve the CPU general-purpose registers or FCW 
flag byte. EPU internal operations do not require any 
data transfers. After the data transfers for the EPU in- 
struction are completed, the CPU can continue process- 
ing while the EPU performs the operation. While the EPU 
is processing an instruction, it can drive the EPUBSY 
signal to stop the CPU. 


Extended Instructions 


The data processing operations performed by the EPU 
are transparent to the CPU. The EPU can execute 
floating point operations, decimal arithmetic, specialized 
operating system functions, signal processing opera- 
tions, or any other that the system designer chooses. For 
this reason, no mnemonic is listed for the extended in- 
structions, as the mnemonic will depend on the type of 
EPU. EPUs designed to speed execution of special pur- 
pose operations can provide significant performance im- 
provements. The operation of the EPU can be over- 
lapped with operation of the CPU and other EPUs. 


The EPA bit in the Flag and Control Word register in- 
dicates whether an EPU is present. If no EPU is present, 
the CPU traps EPA instructions for software simulation. 
Thus, the EPA facility can be used even with no external 
support circuitry. This allows software compatibility be- 
tween systems, whether or not an EPU is present. The 
system designer can choose to include an EPU in high- 
performance systems but not in low-cost systems, and 
software can be developed using the EPA instructions 
before an EPU is available. 


Operation 
Operands 
Addressing Modes 


Load EPU from memory 
dst - 
src 
(n bytes or words) 


Load memory from EPU 


dst - 
src 
(n bytes or words) 


Load EPU from CPU 


dst - 
src 
(n words or longwords) 


Load CPU from EPU 


dst - 
src 
(n words or longwords) 


Load EPU from Flags 
dst - 
src 


Load Flags from EPU 


dst - 
src 


EPU Internal Operation 


·Compact mode allows BX with no displacement for EAM. 
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dst,src, n 


dst,src,n 


dst,src, n 


dst,src,n 


dst,src 


dst,src 


dst: EPU 
src: IM,IR,EAM* 
n: 1M 


dst: IR,EAM* 
src: EPU 
n: 1M 


dst: EPU 
src: R 
n: 1M 


dst: R 
src: EPU 
n: 1M 


dst: EPU 
src: FLGR 


dst: FLGR 
src: EPU 


CACHE 


The CPU implements a Cache mechanism to keep on- 
chip copies of the most recently referenced memory 
locations (Figure 10). The CPU examines the cache on 
memory fetches to determine if the addressed data are 
located in the cache. If the information is in the cache (a 
hit), then the CPU fetches from the cache, and no tran- 
saction is necessary on the external interface. If the in- 
formation is not in the cache (a miss), then the CPU per- 
forms a Memory Read transaction to fetch the missing 
information. 


The cache stores data in blocks of 16 bytes. Each data 
word in the cache has an associated validity bit to in- 
dicate whether or not the word is a valid copy of the cor- 
responding main memory location. The cache contains 
16 blocks, providing 256 bytes of storage. 


The cache is fully associative, so that a block currently 
needed and missing in the cache can replace any block 


ADDRESS TAG 
ASSOCIATIVE 
MEMORY 
(16 x 28) 


MATCH r----..,.-----. 


LINES 
CACHE DATA VALIDITY 


J-=o1=r6 -,-.... MEMORY 
BITS 


BLOCK 
HIT 


PHYSICAL 
ADDRESS 


(16 x 128) 
(16 x 8) 


32 


DATA 
CACHE 


HIT 


Figure 10. Cache Organization 


PIN DESCRIPTIONS 


The CPU .has 58 signal lines. Pin functions are'shown in 
Figure 11. 


ADo-AD31. Address/Data (Bidirectional, active High, 
3-state). These 32 lines are time-multiplexed to transfer 
address and data. At the beginning of each transaction 
the lines are driven with the 32-bit address. After the ad- 
dress has been driven, the lines are used to transfer one 
or more bytes, words, or longwords of data. 


AS. Address Strobe (Output, active Low, 3-state). The ris- 
ing edge of AS indicates the beginning of a transaction 
and shows that the address, STo-ST3, R/W, BUW, BwiC, 
NIS, and BRST are valid. 
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in the cache. Moreover, when a block miss occurs, the 
least recently used (LRU) block in the cache is replaced. 
When a cache miss occurs on an instruction fetch, the 
CPU fetches the missing instruction from memory and 
prefetches the following words in the block using a Burst 
transaction. When a cache miss occurs on an operand 
fetch, the CPU fetches the missing data from memory. 
(The CPU uses Burst transactions only for fetching 
operands when more than one data transfer is 
necessary: longword operands on a 16-bit bus, un- 
aligned operands, string instructions, Load Multiple in- 
structions, and loading Program Status.) 


On store references, the data is written to memory (store 
through), and if the reference hits in the cache, the data 
is also written to the cache. If the store reference misses 
in the cache, the cache is unaffected. 


Software has some control ,over the cache. The cache 
can be selectively enabled for instruction and data 
references by bits CI and CD in the SCCL control 
register. The memory management mechanism allows 
cacheing to be inhibited for individual pages. The 
Pcache instruction can be used to invalidate all informa- 
tion in the cache. 


The cache has an option, controlled by bit CR in SCCL, to 
inhibit block replacement on a miss. This option can be 
used to lock fixed locations into the cache for fast, on- 
chip access. To do this, the cache is first enabled for 
block replacement of data references only. Selected 
blocks are read into the cache. The block replacement 
algorithm is then disabled, while the cache is enabled for 
instruction and data references. 


BUSREQ. Bus Request (Input, active LOW). A Low on this 
line indicates that a bus requestor has obtained or is try- 
ing to obtain control of the local bus. . 


BUSACK. Bus Acknowledge (Output, active LOW). A Low 
on this line indicates that the CPU has relinquished con- 
trol of the local bus in response to a bus request. 


BRST. Burst (Output, active Low, 3-state). A Low on this 
line indicates that the CPU is performing a burst transfer; 
i.e, multiple Data Strobes following a single Address 
Strobe. 
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BRSTA. Burst Acknowledge (Input, active Low). A Low 
on this line indicates that the responding device can sup- 
port burst transfers. 


BUW; ,BW/L Byte, 
Longword/Word; Byte, 
Word/ 
Longword (Output, 3-state). These two lines specify the 
data transfer size. 


BuW 
BW/L 
Size 


High 
High 
Byte 
Low 
High 
Word 
High 
Low 
Longword 
Low 
Low 
Reserved 


OS. Data Strobe (Output, active Low, 3-state). DSis used 
, for timing data transfers. 


EPUBSY. EPU Busy (Input, active Low). A Low on this 
line indicates that an EPU is busy. This line is used to 
synchronize the operation of the CPU with an EPU during 
execution of an EPA instruction. 


GREQ. Global Request (Output, active Low, 3-state). A 
Low on this line indicates the CPU has obtained or is try- 
ing to obtain control of a global bus. 


GACK. Global Acknowledge (Input, active Low). A Low 
on this line indicates the CPU has been granted control 
of a global bus. 
' 


IE. Input Enable (Output, active Low, 3-state). A Low on 
this line can be used to enable buffers on the AD lines to 
drive toward the CPU. 
' 


NMI. Non-Maskable Interrupt (Input, Edge activated). A 
High-to-Low transition on this line' requests a non- 
maskable interrupt. 


RESET 


EXTENDED 


PROCESSOR 
- 
EPii'iiSv 


CONTROL 


l 


-NM' 
INTERRUPT 
~ 
REQUESTS 


. 
NVI 


LOCAL BUS { 
CONTROL 


GLOBAL BUS 
GREQ 


CONTROL 
_ 
GACK 


NVI. Non-Vectored Interrupt (Input, active Low). A Low 
on this line requests a non-vectored interrupt. 
Nis. Normal/System Mode (Output, Low = System 
Mode, 3-state). This line indicates whether the CPU is in 
Normal or System mode. 


OE. Output Enable (Output, active Low, 3-state). A Low 
on this line can be used. to enable buffers on the AD lines 
to drive away from the CPU. 


ClK. Clock (Input). This line is the clock used to 
generate all CPU timing. 


RIW. Read/Write (Output, Low = 'Write, 3-state). This 
signal indicates the direction of data transfer. 


RESET. Reset (Input, active Low). A Low on this line 
resets the CPU. 


RSPO-RSP1. Response (Input). These lines encode the 
response to transactions initiated by the CPU. Note that 
RSPo and RSP1 can be connected together for ZeBUS 
WAIT timing. 


RSPo 
RSP1 
Response 


High 
High 
Ready 


Low 
High 
Bus Error 
High 
Low 
Bus Retry' 


Low 
Low 
Wait 


STO-ST3' Status (Output, active High, 3-state). These 
lines specify the kind of transaction occurring on the 
bus. (See Table 4.) 


VI. Vectored Interrupt (Input, active Low). A Low on this 
line requests a vectored interrupt. 


AD 4- 


AS 
os 


RiW 


BuW 


BW/[ 


STATUS 


ClK 


ADDRESSIDATA 
BUS 


BUS STATUS 
AND TIMING 


} 
BUFFER 
CONTROL 


} 


BURST TRANSFER 
CONTROL 


+5 V 
GND 
CLOCK 


,Figure 11. Pin Functions 
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MULTIPROCESSOR CONFIGURATIONS 


The CPU provides support for interconnection in four 
types of multiprocessor configurations (Figure 12): 
coprocessor, slave processor, tightly-coupled multiple 
CPUs, and loosely-coupled multiple CPUs. 


Coprocessors, such as the Z8070 Arithmetic Processing 
Unit, work synchronously with the CPU to execute a 
single instruction stream using the Extended Processing 
Architecture facility. The signal EPUBSY is dedicated for 
connection with qoprocessors. 


Slave processors, such as the Z8016 DMA Transfer Con- 
troller, perform dedicated functions asynchronously to 
the CPU. The CPU and slave processor share a local 
bus, of which the CPU is the default master, using the 
CPU's BUSREQ and BUSACK lines. 


LOCAL BUS 


Tightly-coupled, multiple CPUs execute independent in- 
struction streams and generally communicate through' 
shared memory located on a common (global) bus using 
the CPU's GREQ and GACK lines. Each CPU .!s default 
master of its local bus, but the global bus master is 
chosen by an external arbiter. The CPU also provides 
status information about interlocked memory references 
(for Test and Set, Increment Interlocked, and Decrement 
Interlocked instructions), which can be used with multi- 
ported memories. 


Loosely-coupled, multiple CPUs generally communicate 
through a muftiple·ported peripheral, such as the Z8038 
FlO. The Z80,000 CPU's 110 and interrupt facilities can 
support loosely·coupled multiprocessing. 


(D) LOOSELY·COUPLED 


MULTIPLE CPU 
(C) TIGHTLY·COUPLED MULTIPLE CPU 
(8) SLAVE PROCESSOR 
(A) COPROCESSOR 


Figure 12. Multiprocessor Configurations 


HARDWARE INTERFACE CONTROL 
REGISTER 


The Hardware Interface Control register (HICR) specifies 
certain characteristics of the hardware configuration 
surrounding the CPU, including bus speed, memory data 
path width, and number of automatic Wait states. The 
physical memory address space is divided into two sec- 
tions, Mo and M1, selected by bit 30 of the address. A 
typical system would locate slow, 16-bit wide bootstrap 
ROM in Mo and faster 32-bit wide dynamic RAM in M1. 
The physical 110 address space is similarly divided into 
two sections, 1100 and 1101, selected by bit 30 of the ad- 
dress. 


Fields 
in 
H1CR 
specify 
the 
following 
interface 
characteristics (see Figure 3): 
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Bus speed (S)-The bus clock frequency is either 112 or 
114 the clock frequency. 


Memory data path (Mo.DP, M1.DPJ-The data path width 
for Mo and M1 are each specified as 16 or 32 bits. 


Automatic Wait states (Mo. W, M1. W, 1/00. W, 1/01. W, 
lACK. W1, 
lACK. W2)-The number of Wait states 


automatically inserted by the CPU for references to Mo, 
Ml, 1100, 1101, and I nterrupt Acknowledge, are separate- , 
Iy specified. 


Global bus protocol control (LAO, GE)-The CPU can ac- 
cess a global bus (a bus shared with other CPUs). On 
references to the global bus, the CPU must use a re- 
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quest/acknowledge handshake with an external arbiter. 
The GE field enables the use of the global bus; the LAD 
field selects the portion of the address space used for 
references to the global bus. 


Minimum Address Strobe rate (MASR)-This optional 
feature ensures that an Address Strobe will be 
generated at least once every 16 bus clock cycles. This 


CPU TIMING 


The CPU performs transactions on the external interface 
to transfer data for fetching instructions, fetching and 
storing operands, processing exceptions, and perform- 
ing memory management. In addition, the CPU performs 
Internal Operation and Halt transactions, which do not 
transfer data. Each transaction occurs during a se- 
quence of bus clock cycles, named T 1, T 2, etc. 


The CPU has a single clock line, ClK, used to generate 
all timing. Internally, the CPU derives another clock for 
bus timing by dividing ClK by 2 or 4. The scale factor for 
bus timing (2 ot 4) is selected at Reset. In the AC timing 
characteristics for the CPU, input setup and hold times 


CLK 


BCLK ~ 


AD~ 


is'useful for refreshing pseudostatic RAMS. 


EPU overlap (EPUO)-This bit, along with another bit in 
an EPU control register, controls the degree of overlap 
for CPU and EPU operations. The degree qf overlap can 
be limited to simplify debugging and recovery from ex- 
ceptions, although to do so reduces overall execution 
speed. 


and output delays are specified with respect to a rising 
edge of ClK. When CPU output transitions "occu"r on dif- 
ferent clock edges, the time between the transitions is 
specified in terms of a constant delay and a variable 
number of ClK cycles. The number of ClK" cycles 
depends on the bus timing scale factor, type of" trans- 
action, and number of Wait states. 


In the logical timing diagrams that follow, the signal tran- 
sitions on the bus are shown in relation to the bus clock, 
BClK. The beginning of a transaction, signified by a fail- 
ing edge of AS, always occurs on a rising edge of BClK. 
The BClK signal is derived internally to the CPU as 


AS ~ 
ADDRESS }-------< DATAIN}--" 


(A) BCLK = CLK -7 2 


CLK 


BLCK ~ 


AD J~ 
___ 
A_DD_R_ES_S ___ ~)- - 
- 
- 
- 
- 
- 
- 
- 
- 
- 
- 
- 
-('\", __ 
DA_TA_IN_-.Jr - 
- 
- 
- 
- ~ 


\~--------------~I 


(B) BCLK = CLK + 4 ' 


-Figure 13. Memory Read Timing for Different Bus Scale Factors 
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described above, but is not available on the pins. BClK 
can also be derived externally to the CPU by dividing 
ClK by the selected bus timing. scale factor. (The Reset 
section discusses synchronization of the internal and ex- 
ternal bus clocks). The timing diagrams in Figure 13 
show example memory read transactions using. the dif- 
ferent scale factors. 


BUS TRANSACTIONS 


All bus transactions begin with Address Strobe (AS) 
asserted and then negated. On the rising edge of AS the 
lines for status (STo-ST3), Read/Write (R/W), data 
transfer size (BW/L, BUW), and Normal/System (NiS) are 
valid. The status lines indicate the type of transaction be- 
ing initiated (Table 4). The R/W line indicates the direc- 
tion of data transfer. The data transfer size indicates 
whether a byte, word, or longword of data is being 
transferred. The N/S line indicates the CPU's operating 
mode. The following sections describe timing for the dif- 
ferent transactions. 


ST3-STo 


0000 
0001 
0010 
a 01 1 
0100 
a 1 01 
01 1 a 
01 1 1 
1000 
100 1 
1010 
1 01 1 
1 100 
1 1 01 
1 1 1 a 
1 1 1 1 


Tablo 4. Status Codes 


Definition 


internal operation 
CPU-EPU (data) 


1/0 
halt 
CPU-EPU (instruction) 
N M I acknowledge 


NVI acknowledge 
Vi acknowledge 
cacheable CPU-memory (data) 


non·cacheable CPU-memory (data) 
cacheable EPU-memory 
non-cacheable EPU-memory 


cacheable CPU-memory (instruction) 
non-cacheable CPU-memory (instruction) 


reserved 
interlocked CPU-memory (data) 


On the rising edge of AS, the address on the AD lines is 
also valid. Addresses are not required and therefore are 
undefined 
for 
Internal 
Operation, 
Halt, 
Interrupt 


Acknowledge, and CPU-EPU data transactions. 


The CPU uses Data Strobe (DS) to time the data transfer. 
(Internal Operation and Halt transactions do not transfer 


In the description of bus transactions that follow, the 
term "asserted" means an active signal and "negated" 
means an inactive signal. A signal is either active when 
High or when low, as specified in the pin functions. 


data, and thus do not assert DS.) For Write operations 
(R/W = low) the CPU asserts DS when valid data is on 
the AD lines. For Reaq operations (R/W = High) the CPU 
makes the AD lines 3-state before asserting DS, so the 
addressed device can put its data on the bus. The CPU 
samples the data in the middle of a bus cycle, while 
negating DS. 


The AD lines can be used to transfer bytes, words, or 
longwords. For Read transactions, the three cases are 
handled as follows: 


m Byte transfers use ADo-AD7; ADa-AD31 are ignored. 


m Word transfers use ADo-AD15; AD16-AD31 are 
ignored. 


CI 
longword transfers use ADo-AD31. 


For Write transactions, the three cases are handled as 
follows: 


II Byte transfers replicate the data on ADo-AD7, 
ADa-AD15, AD16-AD23, and AD24-AD31. 


• 
Word transfers replicate the data on ADo-AD15 and 
AD16-AD31· 


1'1 
longword transfers use ADo-AD31. 


The signals Input Enable (iE) and Output Enable (OE) can 
be used to enable buffers on the bidirectional AD lines. 
IE is asserted when the buffers drive toward the CPU; OE . 
is asserted when the buffers drive away from the CPU. 
Whenever the direction for the AD lines changes, neither 
iE nor OE is asserted for at least one ClK cycle. 


To transfer more than one data item, the CPU can per- 
form Burst transactions. The data items are transferred 
in the same direction, and must be equal in size. Data 
Strobe is used to time each transfer. The CPU asserts 
Burst (BRST) to indicate a burst transfer. The responding 
device asserts Burst Acknowledge (BRSTA) if it is 
capable of supporting burst transfers. If BRSTA is not 
asserted, the CPU transfers only a single data item. 
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RESPONSE 


Any time data is transferred, the responding device 
returns a code on the Response lines (RSPo-RSP1) to in- 
dicate Ready, Wait, Bus Error, or Bus Retry. The 
response is sampled at a time specific to each type of 
transaction, generally before the AD lines are sampled 
or OS is negated. 


Ready indicates the completion of a successful transfer. 


Wait indicates that the responding device· needs more 
time to complete the transaction. The CPU waits one bus 
cycle before sampling the response again to accom- 
modate slow memory or peripherals. 


Bus Error indicates that a fatal error has occurred during 
the transaction; for example, bus timeout for a nonexis- 
tent device. Bus Error is treated as an exception by the 
CPU. 


CPU-MEMORY TRANSACTIONS 


The CPU uses status 1000, 1001, .1100, 1101, or 1111 to 
read from and write to memory. The transactions involve 
a single data transfer or multiple, burst data transfers. 


Single Memory Read 


Figure 14 shows timing for a single memory read trans- 
action with no Wait states. AS is asserted during the first 
half of T1. The rising edge of AS indicates that the ad- 
dress on AD and control signals SIo-ST3, R/W, BW/L, 
BLlW, and N/S are valid. The control signals remain valid 
for the duration of the transaction. BRST is negated dur- 
ing the transaction because only a single data item is be- 
ing transferred. At the beginning of T2 the CPU stops 
driving the address, asserts OS, and prepares to receive 
data from memory. In the middle of T2 RSPo-RSP1 are 
sampled Ready, the input data is latched, and OS is 
negated. The signal DE is asserted during T1; however, 
for this two-cycle read transaction, IE is not asserted. 


The CPU can insert Wait states in the middle of T2 if 
RSPo-RSP1 are sampled Wait or if automatic Wait states 
are programmed in the appropriate field of HICR. The 
duration of a Wait state is one BCLK cycle. 


The timing for a single memory Read transaction with 
one Wait state is shown in Figure 15. This is not a true 
Wait state because IE is asserted in the middle of T 2 and 
continues until the middle of T3. For memory Read trans- 
actions longer than two bus cycles, either because of 
Wait states or Burst transfers, IE is asserted from the 
middle of T2 until the end of data transfer. The signals OE 
and IE can be used to control buffers on the AD lines. 


For memory Read transactions, the data transfer size is 
equal to the data path width specified in H ICA. The 
memory should transfer the aligned longword addressed 
by AD2-AD31 (ignoring ADo-AD1) for a 32-bit data path 
or the aligned word addressed by AD1-AD31 (ignoring 
ADo) for a 16-bit data path. The CPU selects the required 
bytes from the transferred word or longword. 
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Bus Retry indicates that the transaction should be tried 
again; for example, a transient parity error is detected. 
The CPU tries the transaction again. 


The CPU can insert Wait states automatically under con- 
trol of several fields in the Hardware Interface Control 
Register. If an automatic Wait state is programmed for a 
bus cycle, the CPU ignores the response and Wait is 
assumed. Thus, Wait states can be inserted automatic- 
ally by the CPU or upon request of the responding 
device. 


It must be emphasized that the RSPo-RSP1 lines are syn- 
chronous. Thus, they must meet the specified setup and 
hold times for correct operation. A simple system using 
only Z~BUS WAIT can be implemented by connecting 
WAIT to RSPo and RSP1. 


i 
T1i- 
T2·-1 


BCLK --.J 
1 
1* 
I 


AD =x 
ADDRESS >--®--C 


I 


R/W.-J 
~. 


STo-ST3 =x 
)( 
BW/i:, BLlW 
HIS 
. __________ 
_ 


\ 


*RSPo-RSPl and data sampled. 


Figure 14. Single Memory Read Timing 
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2071-015 00-2071-01 


r-Tl~I~T2~I-T31 


DCLK .-J 


AD J 
ADDRESS 


STO-ST3 =x 
BwiL, BL/\! 
HIS 
.~ __________________________________ _ 


*RSPo-RSPl and data sampled. 


Figure 15. Single Memory Read Timing (1 Wait State) 
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Single Memory Write 


A single memory Write transaction (Figure 16) begins 
with AS to indicate that address and control signals are 
valid. At the beginning of T2, the CPU stops driving the 
address and starts driving the data. In the middle of T2, 
OS is asserted. The CPU negates OS in the middle of T3. 
OEis asserted beginning at T1 and continues for the 
duration 
of 
the 
transaction. 
The 
CPU 
samples 


RSPo-RSP1 in the middle of T 3. 


For memory Write transactions, the data transfer size is 
less than or equal to the data path width specified in 
H ICA. Bytes and words can be written to a 16-bit 
memory; bytes, words, and longwords can be written to 
a 32-bit memory. The CPU writes bytes to any address, 
but words and longwords are always written to an 
aligned address (i.e., words are always written to an 
even address and longwords are always written to an ad- 


dress that is a multiple of four). When a program writes a 
word or longword to an unaligned address, the CPU per- 
forms two or more write transactions to aligned ad- 
dresses. For example, if the program writes a word to an 
odd address, the CPU first writes the more Significant 
byte to the odd address, then it writes the less Significant 
byte to the successive even address. 


Single memory read and write timing differ slightly from 
loBUS specificatiOns. The minimum Read transaction is 
two bus cycles, and the slave response is sampled at the 
end of the data transfer. For the loBUS, the minimum 
Read transaction is three cycles, and the slave response 
is sampled one cycle before the end of the data transfer. 
For strict loBUS compatibility, it is possible to program 
one automatic Wait state for memory read and to delay 
the slave response with an external flipflop. 


I~T1~IT2~IT31 


BCLK~ 
I 
I 
I 
I 
1* 
I 


AD J 
ADDRESS X'-____ 
D_AT_A_O_UT ____ ,X 


\. 


\,------,1 


IE 


ow/i:", OLl\! 
V 
STC-ST:- 
)L 


tllS ----" ________________ 
. 


RiW~ 
;= 


• RSPo- RSP1 sampled. 


Figure 16_ Single Memory Write Timing 
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Burst Memory Transactiomj 


Burst memory transactions use multiple Oata Strobes 
following a single Address Strobe to transfer data at con- 
secutive memory addresses. The signals BRST and 
BRSTA control the Burst transaction. The CPU uses 
Burst transactions to prefetch a cache block on an in- 
struction fetch cache miss. The CPU also uses Burst· 
transactions to fetch or store operands when more than 
one transfer is necessary, as with unaligned operands, 
string instructions, Load Multiple instructions, and 
loading of program status. 


If the memory does not support Burst transfers, the 
Burst transfer protocol described below (Figure 17) 
allows BRSTA to be tied High. The CPU then separates 
the Burst transaction into a sequence of single transfers. 


At the beginning of a Burst transaction, the CPU asserts 
BRST along with other control signals. When the CPU 
continues to assert BRST at 1he falling edge of OS, this 
indicates to memory that the CPU· can support another 
data transfer following the one in process. When the 
CPU negates BRST before the falling edge of OS, this in- 
dicates to memory that the current transfer is the last in 
the transaction. 


When BRSTA is asserted at the time the RSPo-RSP1 
lines are sampled Ready, this indicates to the CPU that 
memory can support another data transfer following the 
one in process. When BRSTA is negated at the time the 
RSPo-RSP1 lines are sampled Ready, this indicates to 
the CPU that the current data transfer is the last in the 
transaction. 


The Burst transaction can be terminated by either the 
CPU or memory. If memory terminates the transfer by 
negating BRSTA, the CPU responds by negating BRST 
when OS is negated. (See the e~ample for Burst Memory 
Read.) If the CPU terminates the transfer by negating 
BRST before the falling edge of OS, memoryresponds by 
negating BRSTA. (See the example for Burst Memory 
Write.) The CPU terminates the burst transaction when 
all the required data items have been transferred or after 
reaching the end of an aligned, 16-byte block. 
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Figure 17. CPU Burst Transfer Protocol 
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Burst Memory Read 


Figure 18 shows timing for a Burst Memory Read trans- 
action with one Wait state. In this example, three data 
items are transferred, after which memory terminates 
the burst. BRST is asserted at the beginning of T 1; other- 
wise, the timing for the first transfer is identical to a 
single memory read. In the middle of T 3 the CPU 
samples RSPo-RSP1 Ready, latches the data, and 
samples BRSTA active. During T4 the second data item 
is transferred, accompanied by OS. The time for the 


second and subsequent transfers can be extended with 
wait states if· RSPo-RSP1 are sampled Wait; the CPU 
does not insert automatic Wait states after the first 
transfer. 


During T5 the third data item is transferred. At the same 
time the RSPo-RSP1 lines are sampled Ready, the data 
is latched and BRSTA is sampled inactive. Memory ter- 
minates the Burst transfer, and the CPU responds by 
negating BRST. 


3 DATA TRANSFERS, MEMORY TERMINATES BURST 
'~T11~T2---"~T3 
-,.. 
T4-.'-TS----...' 


BCLK ~ 
I. 
I. 
1 I. 
I. 
I 


~WAIT STATE-.J 


AD =X"",-A_D_D_RE_SS_..J)- - 
- 
- 
- -( 
DATA IN X DATA IN X DATA IN 
)---C 


\. 


OE ___ 
\~_--JI 


\~-------------------------------~ 
RiWJ 


STo-ST3 
X 
BwlL, BLlW 


N~ 
• ~,------------------------------~---------------------- 


BRST ~~ 
______________________________________________ --..J 


°RSPo- RSP1, BRSTA, and data sampled; 


Figure 18. Burst Memory Read Timing (1 Wait State) 
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Burst Memory Write 


Figure 19 shows timing for a Burst Memory Write trans- 
action with no Wait states. In this example, two data 
items are transferred, and the CPU terminates the burst. 
BRST is asserted at the beginning of T1; otherwise, the 
timing for the first transfer is identical to a single 
memory write. In the middle of T3 the CPU samples 
RSPo-RSP1 Ready and BRSTA active. At the beginning 
of T4 the CPU n~gates BRST indicating that one more 


data transfer will follow. During T4 the second data item 
is transferred, accompanied by OS. The time for the se- 
cond and subsequent transfers can be extended with 
Wait states if RSPo-RSP1 are sampled Wait; the CPU 
does not insert automatic Wait states after the first 
transfer. Memory recognizes that the CPU has ter- 
minated the burst transfer and responds by negating 
BRSTA before the end of T4. 


2 DATA TRANSFERS, CPU TERMINATES BURST 


~T1----"I""'---T2----'I"-T3----'I""'--T4~1 


DCLK~ 
I. 
I. 
I 


AD J 
ADDRESS X 
DATA OUT 
X DATA OUT >C 


IE 


RiW~ 


STo-5T3 =x 
>C 
DW/L, BUW 
HIS 
.~ ________________________________________ 
~. 


DRST ~"-__________ ---J/ 


\ ____ 
\.a.......-~/ _ 
___J7 


*RSPO-RSP1, BRSTA sampled. 


Figure 19. Burst Memory Writo Timing 


Interlocked Memory Transactions 


In some multiprocessing configurations, the CPU must 
inhibit other bus masters from referencing shared 
memory while the CPU performs two or more transac- 
tions. The CPU does this by using status 1111 with any of 
the memory transactions described above. A status of 
1111 indicates a non-cacheable data reference with in- 


2071-019 


terlock protection. The CPU uses interlock protection for 
data references associated with Test and Set, Decre- 
ment Interlocked, and Increment Interlocked instruc- 
tions. The CPU also uses interlock protection for 
references to address translation table entries when 
loading the Translation Lookaside Buffer. 
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INPUT/OUTPUT TRANSACTIONS 


The CPU uses status 0010 to read from and write to 1/0 
ports. 1/0 transactions are generated by I/O instructions 
and, when address translation is enabled, by data 
references to pages with bit 31 of the page table entry 
set to 1. 


The timing for 1/0 and memory transactions is very 
similar. The major difference is that DS falls in the mid- 
dle of T2 for 1/0 read timing, compared to the beginning 
of T2 for memory read timing. This allows peripheral 


devices more time for address decoding~ Another dif- 
ference is that the data transfer size (byte, word, or 
longword) for I/O transactions is specified by the instruc- 
tion, not by HICR. The final difference is that the CPU 
does not support Burst I/O transactions. Figure 20 shows 
timing for an 110 Read transaction. Single 110 Write tim- 
ing is the sam~ as that shown for a single memory write 
(Figure 16). 


AD ~ 
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Figure 20. 1/0 Read Timing 
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EPU TRANSACTIONS 


The CPU and EPU cooperate in the execution of EPA in- 
structions (Figure 21). When the CPU encounters an EPA 
instruction and the EPA bit in the FCW is 1, the CPU 
broadcasts the first two words of the instruction to the 
EPUs in the system using the CPU-EPU instruction 
transfer transaction. All EPUs in the system recognize 
the transaction, but only one of four possible EPUs is 
selected by bits 16 and 17 of the EPU instruction. The 
CPU also transfers the PC value for the instruction, 
which the selected EPU saves for use in exception 
handling. If data transfers are required to complete the 
instruction, the CPU controls the data transfer transac- 
tions while the EPU drives or receives the data. 


The signal EPUBUSY, output from the EPU, is used to 
synchronize the CPU and EPU in executing EPA instruc- 
tions. The CPU must sample EPUBSY inactive before in- 
itiating an EPU instruction transfer. If data transfers are 
required, the CPU must sample EPUBSY inactive before 
initiating the first transfer. EPUBSY is also used to con- 
trol the degree of overlap between CPU and EPU instruc- 
tion execution. Ordinarily, the CPU can continue pro- 
cessing other instructions after performing the data 
transfers associated with an EPA instruction and before 
the EPU has completed executing the instruction. To 
simplify debugging and recovery from exceptions, a 
Non-Overlap mode is provided, controlled by the EPU 0 
bit in HICR. In Non-Overlap mode, the CPU samples 
EPUBSY in the middle of the bus cycle during which the 
last data transfer for an EPA instruction occurs. If 
EPUBSY is asserted, the CPU ceases processing in- 
structions or interrupts until EPUBSY is sampled inactive 
in the middle of a bus cycle. 


To simplify system hardware, the AD lines for CPU and 
EPU should be wired together with no buffers between 
them. If the AD lines are separated by buffers, external 
circuitry must generate iE and OE timing for CPU-to-EPU 
Data Read and EPU-to-Memory Write transactions. 
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Figure 21. EPA Instruction Processing 
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CPU·to·EPU Instruction Transfer 


Figure 22 shows timing for a CPU-to-EPU Instruction 
Transfer transaction with status 0100. The rising edge of 
AS indicates that AD lines and status are valid. During 
T1, the AD lines are used to transfer the opcode, i.e., the 
first two words of the EPA instruction. At the beginning of 


*EPUBSY sampled. 
+ EPUBSY sampled If EPU Internal operation. 


T 2 the CPU stops'driving the opcode, asserts DS, and 
starts driving PC on the AD lines. The CPU negates DS in 
the middle of T 2. The data transfer size for the transac- 
tion is longword. The CPU ignores RSPo-RSP1. 


Figure 22. CPU·to-EPU Instruction Transfer Timing 
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CPU·to·EPU Data Transfer Transactions 


Transactions to transfer data between the CPU and EPU 
use status 0001. The EPA instructiOn opcode indicates 
the number of words to be transferred. One or more 
longwords of data are transferred until all words have 
been transferred. If the last transfer contains a single 
word, 
the data is 
replicated on ADo-AD1S 
and 
AD1S-AD31. The CPU does not assert BRST and ignores 
RSPo-RSP1 and BRSTA. 


Figure 23 shows timing for a CPU-to-EPU Data Read 
transaction. This example has two data'transfers; any 


number of data transfers between one and eight is possi- 
ble. The rising edge of AS indicates that status and con- 
trol signals are valid. The CPU stops driving the AD lines 
at the end of T1, and the EPU begins driving the AD lines 
in the middle of T2. At the beginning of T3, the CPU 
asserts DS. In the middle of T3, the CPU samples the 
data and negates DS. The second longword of data is 
transferred during T4. After the last data transfer, the 
CPU inserts an idle bus cycle (Ts in the example) during 
which neither the CPU nor EPU drive the AD lines. 
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Figure 23., CPU·to-EPU Data Read Timing 
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Figure 24 shows timing for a CPU-to-EPU data write 
transaction. This example has three data transfers; any 
number of data transfers between one and eight is possi- 
ble. Timing for the first transfer is identical to the CPU-to- 


EPU instruction transfer transaction. A second longword 
of data is transferred during T3. and the third longword is 
transferred during T4. 
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Figure 24. CPU·to·EPU Data Write Timing 
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EPU·to·Memory Trans~ction5 


The CPU uses status 1010 or 1011 for the EPU to read 
from and write to memory. The timing is identical for 
EPU-to-memory read and CPU-to-memory read. The EPU 
monitors the CPU timing on the bus, and uses the two 
least significant address bits, the data transfer size, and 
the length of the operand from the instruction to select 
the bytes it needs from the AD lines. 


The timing for an EPU-to-memory write transaction dif- 
fers slightly from a CPU-to-memory write transaction. 
Two extra bus cycles are included to pass the AD lines 
from the CPU to EPU after the address transfer and from 
EPU back to CPU after the last data transfer. Figure 25 
shows an example for a single EPU-to-memory write 
transaction with no Wait states. The CPU stops driving 


the AD lines 'at the end of T1; the EPU begins driving 
them in the middle of T2. DS is asserted in the middle of 
T3, one bus cycle later than for CPU-to-memory write 
timing. The CPU negates D~ in the middle of T4. The CPU 
can insert Wait states in the middle of T 4. The EPU con- 
tin!Jes to drive the AD lines until the end of T4. After the 
last data transfer the CPU inserts an idle bus cycle (T5 in 
this example) during which neither the CPU nor EPU 
drive the AD lines. EPU-to-memory burst write transac- 
tions are similarly extended by two bus cycles more than 
with CPU-to-memory burst write timing. One cycle is in- 
serted before the first data transfer, and another after 
the last data. transfer. 


~ 
_____ 
E_PU_D_A_TA_O_U_T _____ .J>-- - - --c 


[ 


[ 


~ 
______________________________ K 


*EPUBSY sampled. 
__ 
+ RSPo-RSPl sampled; EPUBSY sampled if last tran!!action. 


Figure 25. EPU·to-Memory Single Write Timing 


2071-025 
731 


INTERRUPT REQUEST AND 
ACKNOWLEDGE 


The CPU recognizes vectored, nonvectored, and non- 
maskable interrupt requests. The decreasing order of 
priority for interrupts is nonmaskable, vectored, and 
nonvectored. NMI is edge sensitive; when NMI is 
asserted, an internal latch is loaded. Vi and NVI are level 
sensitive. 


The CPU samples VI, NVI, and the internal NMI latch on 
the rising edge of ClK. The interrupt request signals can' 
be asynchronous to ClK; the CPU synchronizes them in- 
ternally. 


Figure 26 shows timing for an Interrupt Acknowledge 
transaction, indicated by status 0101,0110, or 0111. The 
timing is similar to a single 1/0 read. Wait states (either 
programmed for automatic insertion or externally 
generated) can be inserted before OS falls in the middle 
of T2 and before OS rises in the middle of T3. Inserting 
Wait states before OS falls allows for delay in the inter- 
rupt priority daisy chain. A word of data is transferred. All 
of the interrupts save the transferred word on the system 
stack for processing the interrupt. Vectored interrupts 
use the low-order byte of the word to select a unique PC 
value from the Program Status Area. 
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Figure 26_ Interrupt Response/Acknowledge Timing 


2071-026 


INTERNAL OPERATION AND HALT 
TRANSACTIONS 


Figure 27 shows timing for Internal Operation (status = 
0000) and Halt (status = 0011) transactions. Unlike 
other bus transactions, data is not transferred in these 
operations. 


Nevertheless, the transfer size for these transactions is 
longword. The minimum duration for the transaction is 
two bus cycles. 


The CPU generates an Internal Operation transaction 
after a sequence of interlocked memory transactions to 
free the memory system lock when no other transactions 
need to be performed. The CPU generates a Halt trans- 
action upon entering Halt State-when the Halt instruc- 
tion is' executed, or when memory indicates Bus Error 
during a fetch or store of Program Status for exception 
processing. The CPU leaves Halt state when an interrupt 
or reset occurs. When the minimum Address Strobe rate 
option is enabled (controlled by bit MASR in HICR), the 
CPU maintains a miniril'um rate for Address Strobes by 
generating Halt transactions in Halt state or Internal 
Operation transactions otherwise. 


BUS RETRY, 


During any transaction in which data is transferred, the 
responding 
device 
can 
indicate 
Bus 
Retry 
on 
RSPo-RSP,. When Bus Retry is indicated, the CPU ter- 
minates the transaction in progress, negating DS and 


BUS ERROR 


During any transaction in which data is transferred, the 
responding device can indicate a bus error exception on 
RSPo-RSP,. When Bus Error is indicated, the CPU ter- 
minates the transaction in progress, negating DS and 
BRST. A bus error exception also causes termination of 
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Figure 27. Internal Operation and Halt Timing 


BRST. If Bus Retry is indicated during a Burst transfer, 
the Retry transaction begins with the address for the 
data transfer where Bus Retry is indicated. 


the instruction in execution. In processing a bus error ex- 
ception, the CPU saves the Program Status, phYSical ad- 
dress for the transaction, and a word identifying the 
status and control signals used for the transaction. 
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BUS REQUEST AND ACKNOWLEDGE 


The 
CPU 
supports 
two 
types 
of 
bus 
request! 


acknowledge sequences, local and global. Other bus 
masters request the local bus from the CPU using a 
handshake of BUSREQ and BUSACK. The CPU requests 
a global bus from an external arbiter using a handshake 
of GREQ and GACK. 


To generate transactions on the local bus, a potential 
bus master (such as a DMA controller) must gain control 
of the bus by making a bus request (Figure 28). A local 
bus request is initiated by asserting BUSREQ. Several 
bus requestors can be wired to the BUSREO signal; 
priorities are resolved externally to the CPU, usually by a 
prioritized daisy chain. 


The CPU samples BUSREO on the rising edge of ClK. 
BUSREO can be asynchronous to ClK;the CPU syn- 
chronizes it internally. After BUSREQ is asserted, the 
CPU completes any transaction or sequence of in- 
terlocked transactions in progress, including possible 


.BCLK~j 


retries. Next the CPU responds by asserting BUSACK 
and placing all other output signals in 3-state. When 
BUSREQ is negated, the CPU negates BUSACK and 
begins driving all other output signals. 


The CPU can initiate transactions with devices located 
on a global bus shared with other CPUs. At any time, only 
one of the CPUs can initiate transactions on the global 
bus. Control of the global bus is arbitrated by external 
circuitry. Before initiating transactions on the global bus, 
the CPU requests control of the global bus from the ar- 
biter using the protocol described below. The CPU uses 
two fields of HICR to distinguish between local and 
global bus transactions. The GE bit enables use of the 
global bus. The 4-bit lA field, which is compared with 
bits 26 to 29 of the physical address, specifies one of six- 
teen. sections of the physical address space to use for 
local references; other references use the global re- 
quest protocol. 
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Figure 28. Local Bus Request/Acknowledge Timing 
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Figure 29 shows timing for the global bus re- 
quest/acknowledge protocol. Before initiating a transac- 
tion on the global bus, the CPU drives the address, 
8To-8T3, BR8T, R/W, N/S, BUW, and BW/L valid at the 
beginning of a bus cycle. Then'i in the middle of the bus 
cycle, the CPU asserts GREQ. When the global bus 
selected by the address is available to the CPU, the ar- 


biter asserts GACK. The CPU samples GACK on the ris- 
ing edge of ClK. GACK can be asynchronous to ClK; the 
CPU synchronizes it internally. The CPU performs one or 
more transactions on the global bus, then negates 
GREQ. The arbiter responds by negating GACK, and the 
CPU can then initiate more transactions. 
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Figure 29. Global Bus Request/Acknowledge Timing 
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Figure 30 shows a state diagram for the local and global 
bus request protocols. To prevent deadlock between 
CPUs referencing each other's local memories, a CPU 
can be preempted while it is waiting for GACK in State 2. 


If BUSREQ is asserted before GACK, the CPU relin- 
quishes the global bus without performing any transac- 
tions. 
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NOTES: Interface signals are High (H). Low (L). High or Low (251). or 3·slaled (3sl). 


Need_G BUS Is an aclive High signal Inlernal 10 Ihe CPU. 


Figure 30. State Diagram for CPU Bus Request Protocol 


Transition Legend 


A local bus request occurs. 


The global bus arbiter grants control of the 
global bus when no global bus request is 
pending. This is an error. The CPU remains in 
State 0. 


The CPU requests the global bus in response 
to the internally generated signal 
NEED_GBUS. 


The local bus master relinquishes the bus. 


_ The global bus arbiter grants the global bus to 
the CPU while no local bus request is pending. 


The global bus arbiter grants the global bus to 
the CPU while no local bus request is pending. 
The arbiter has preempted the CPU. 


The global bus arbiter reclaims the global bus 
before the CPU relinquishes the global bus. 
This is an error. The CPU's response to this 
error is undefined. 


State 0 


State 1 


State 2 


State Legend 


The CPU controls the local bus and is neither 
requesting nor controlling the global bus. 
The CPU can perform transactions on the 
local bus. 


The CPU has granted the local bus. 
The CPU cannot perform transactions. 


The CPU controls the local bus and is reo 
questing the global bus. 
The CPU cannot perform transactions. 


State 3 
The CPU controls the local and global busses. 
The CPU can perform transactions on the 
global bus. 


State 4 
The CPU controls the local bus and is relin- 
quishing control of the global bus. 
The CPU cannot perform transactions. 


H 
The CPU relinquishes control of the global bus 
when it no longer needs the global bus or in 
response to a local bus request. 


The global bus arbiter reclaims the global bus. 
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Reset 


Figure 31 shows reset timing. After RESET is asserted, 
the CPU responds as follows. 


[J 
AD lines are turned to input direction 
o 
AS, BRST, BUSACK, DS, GREQ, iE,' and OE are 
negated 
o 
STo-ST3 are driven to 1111 


o 
BW/[ and BUW are driven low 
o 
N/S and R/W are undefined 


At power on, RESET should be asserted until power has 
stabilized. 


During reset, bits SX, NX, CI, and CD of the SCCl control 
register are cleared, disabling the address translation 


and cache mechanisms. Bit GE of H ICR is also cleared, 
disabling the global bus request protocol. At the rising 
edge of RESET, the relationship between bus timing, 
memory data path, and number of automatic Wait states 
is determined. If RSPo is High at the rising edge of 
RESET, HICR is initialized to a default configuration of 
bus clock scale factor 2, word memory data path, and 
seven automatic Wait s'tates: If RSPo is low at the rising 
edge of RESET, HICR is initialized by latching data from 
the AD lines. RESET need not be synchronous with ClK; 
however, the CPU assumes that the last rising edge of 
ClK on which RESET is asserted corresponds to a rising 
edge of BClK. If RESET is synchronized with the rising 
edge of the external bus clock, the internal and external 
bus clocks will be in phase with respect to ClK. After 
RESET is negated, the CPU fetches FCW from address 2 
and PC from address 4. 


Lj 


II 
RESET ~ 
, 
~~ 
______________________________ 
~~ 
______ • __ -J 


RSPo 


2071-031 


': 
)~ 
; 


" » 


----------~h~'------------------------------~f~------~ 


DATA ; 
IN 


" 
J, 


,': 


r( " 


'f 
); 


" 
iJ 


" " 
" 
)J 


:~: 
'-----J;f----- 


- - -7;-( ADDRESS = 2 


'~ 
r. 
; '----.I . 


" 
» 
::\ 
----------~J~------------------------------~~------------------~;~~~-- 


ALL HIGH 
{;' 
If \STATUS = 1101 


~---\~-------------~£~(--------------Jn~ 


/,1-' ---------------------J;r c= 


Figura 31. Resot Timing 


737 


/' 
Addilional 


HITrliorma lion 


Zilog 


Pioneering the 
Microworld 


Zilog 


Features 


General 
Description 


2031-0045 


Il Multiplexed addressldata bus shared by 
memory and 1/0 transfers. 


Il 16 or more memory address bits; 16-bit 1/0 


addresses; 8 or 16 data bits. 


IJ Supports polling and vectored or non- 
vectored interrupts. 


e Daisy-chain interrupt structure services 
interrupts without a separate priority 
controller. 


The Z-BUS isa high-speed parallel shared 
bus that iinks components of the Z8000 Family. 
It provides family members with a common 
communication interface that supports the 
following kinds of interactions: 


C Data Transfer. Data can be moved between 
bus controllers (such as a CPU) and mem- 
ories or peripherals. 


g Interrupts. Interrupts can be generated by 
peripherals and serviced by CPU saver 
the bus. 


e Resource Control. Distributed management 
of shared resources (including'the bus itself) 
is supported by a daisy-chain priority 
mechanism. 


The· heart of the Z-BUS is a set of multi- 
plexed addressldata lines and the signals that 
control these lines. Multiplexing data and 
addresses onto the same lines makes more effi- 
cient use of pins and facilitates expansion of 
the number of data and address bits. Multi- 
plexing also allows straightforward addressing 
of a peripheral's internal registers, which 
greatly simplifies 1/0 programming. 
A daisy-chained priority mechanism resolves 
interrupt and resource requests, thus allowing 
distributed control of th~ bus and eliminating 
the need for separate priority controllers. The 
resource-control daisy chain allows wide 
physical separation of components, 
The Z-BUS is asynchronous in the sense that 
peripherals do not need to be synchronized 
with the CPU clock. All timing information is 
provided by Z-BUS signals. 


Z·liiJS® 
tCommponermft Hrmiar«:cmIlUtms«:ft 


Summa.r,. 


September 1983 


13 Direct addressing of registers within a 
peripheral facilitates 1/0 programming. 


a Bus signals allow asynchronous CPU and 
peripheral clocks. 


El Daisy-chain bus-request structure supports 
distributed control of the bus. 


e Shared resources can be managed by a 
general-purpose, distributed resource- 
request mechanism. 
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Figure 1. Z-BUS Signals 
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Z-BUS 
A Z-BUS component is one that uses Z-BUS 
,Components 
signals and protocols, and meets the specified 
ac and dc characteristics. Most components in 
the Z8000 Family are Z-BUS components. The 
four categories of Z-BUS components are as, 
follows: 


Other 


'. Components 


Operation 
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CPUs. A Z-BUS system contains one CPU, and 
this CPU has default control of the bus and 
typically initiates most bus transactions. 
Besides generating bus transactions, it handles 
interrupt and bus-control requests. The Z8001 
Segmented CPU and Z8002 Non-Segmented 
CPU are Z-BUS CPUs. 
' 


Peripherals. A Z-BUS peripheral is a com- 
ponent capable of responding to 1/0 trans- 
actions and generating interrupt requests. The 
Z8036 Counter Input/Output Circuit (Z-CIO), 


The Z8 Microcomputer-in its micro- 


processor configuration-conforms to Z-BUS 
timing (which allows it to use Z-BUS 
peripherals and memories), but is miSSing a 
wait input and certain status outputs. 
The Z8010 Memory Management Unit 


(Z-MMU) is a za900 CPU support component 
that interfaces with part of the Z-BUS on the 
CPU side and provides demultiplexed 


'Two kinds of operations can occur on the 


Z-BUS: transactions and requests. At any given 
time, one device (either the CPU or a bus 
requester) has control of the Z-BUS and is 
known as the bus master. A transaction is 
initiated by a bus master and is responded to 
by some other device on the bus. Four kinds of 
transactions occur in Z-BUS systems: 


• Memory. Transfers 8 or 16 bits of data to or 
from a memory location. 


• 1/0., Transfers 8 or 16 bits of data to or from 


a peripheral. 


• Interrupt Acknowledge. Acknowledges 
an interrupt and transfers an identi- 
fication/status vector from the interrupting. 
peripheraL 


• Null. Does not transfer data. Typically used 
for refreshing memory. 
Only one transaction can proceed on the bus 


Z8038 FIFO Input/Output, Interface Unit 
(Z-FIO), the Z8030 Serial Communication 
ControJler (Z-SCC), the Z8090 Universal 
Peripheral Controller (Z-UPC), and the 
Z8052 CRT Controller (Z-CRT) are 'all 
Z-BUS peripherals. 
Requesters. A Z-BUS requester is any com- 
ponent capable of requesting control of the 
bus and initiating transactions on the bus. A 
Z-BUS requester is usually also a peripheral. 
The Z8016 DMA Transfer Controller (Z-DTC) is 
a Z-BUS requester and a peripheral. 
Memories. A Z-BUS memory is one that inter- 
faces directly to the Z-BUS and is capable of 
fetching and storing data in response to Z-BUS 
memory transactions. The Z6132 Quasi-Static 
RAM is a Z-BUS memory. 


addresses on the memory side. 
The "28060 First-In-First-Out Buffer (Z-FIFO) 


is not a Z-BUS component; rather, it is used to 
expand the buffer depth of the Z-FIO or to 
interface the 1/0 ports of the Z-UPC, Z-CIO, 
or Z-FIO to user equipment. 


Z-80 Family components, while not 


Z-BUS compatible, are easily interfaced to 
Z-BUS CPUs. 


at a time, and it must be initiated by the bus 
master. A request, however, may be ini- 
tiated by a component that does not have con- 
trol of the bus. There are three kinds of 
requests: 


• Interrupt. Requests the attention of the 


Z-BUS CPU. 


• Bus. Requests control of the Z-BUS to ini- 


tiate transactions. 


• Resource. Requests control of a particular 
resource. 
When a request is made, it is answered 
according to its type: for interrupt requests an 
interrupt-acknowledge transaction is initiated; 
for bus and resource requests an acknowledge 
signal is sent. In all cases a daisy-chain pri- 
ority mechanism provides arbitration between 
simultaneous requests. 


Signal 
Lines 
The Z-BUS consists of a set of common signal 
lines that interconnect bus components (Figure 
1). The signals on these lines can be grouped 
into four catagories, depending on how they 
are used in transactions and requests. 


Primary Signals. These signals provide 
timing, control, and data transfer for Z-BUS 
transactions. 
ADo-AD1S. Address/Data (acfiveHigh). These 
multiplexed data and address lines carry 1/0 
addresses, memory addresses, and data during 
Z-BUS transactions. A Z-BUS may have 8 or 16 
bits of data depending on the type of CPU. In 
the case of an 8-bit Z-BUS, data is transferred 
on ADo-AD7. 
Extended Address. (active High). These 
lines extend ADo-AD15 to support memory, 
addresses greater than 16 bits. The number of 
lines and the type of address information 
carried is dependent on the CPU. 


Status. (active High). These lines designate 
the kind of transaction occurring on the bus 
and certain additional information about the 
transaction (such as program or data memory 
access or System versus Normal Mode). 
AS. Address Strobe (active Low). The rising 
edge of AS indicates the beginning of a trans- 
action and that the Address, Status, R/W, and 
B/W signals are valid. 
DS. Data Strobe (active Low). DS provides 
timing for data movement to or from the bus 
master. 
R/W. Read/Write (Low = write). This signal 
determines the direction of data transfer for 
memory or I/O transactions. 


B/W. Byte/Word (Low = word}. This signal 
indicates whether a byte or word of data is to 
be transmitted on a 16-bit bus. This signal is 
not present on an 8-bitbus. 
. 


WAIT. (active Low). A Low on this line indi- 
cates that the responding device needsmore 
time to complete a transaction. 
RESET. (active Low). A Low on this line resets 
the CPU and bus users. PeripherC\ls may be 
reset by 
RESET or by holding AS a~d DS Low 
simultaneously. 


CS. Chip Select (active Low). Each perjpheI'al 
or memory component has a CS line that is 
decoded from the address and status lines. A 
Low on this line indicates that the peripheral 
or memory component is being addressed by a 
transaction. The Chip Select information is 
latched on the rising edge of 'AS. 


Bus Request Signals. These signals make 
bus requests and establish. which component 
should obtain control of the bus. 
. 


BUSREQ. Bus Request (active Low). This line. 
is driven by all bus requesters. A Low indi- 
cates that a bus requester has or is trying to 
obtain control of the bus. 


BUSACK. Bus Acknowledge (active Low). A 
Low on this line indicates that the Z-BUS CPU 
has relinquished control of the bus in response 
to a bus request. 
BAI, BAD. Bus Acknowledge In, Bus 
Acknowledge Out (active Low). These signals 
form the bus-request daisy chain. 
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Signal 
CPU 
Requester 
Peripheral 
Memory 


ADo-ADI5 
Bidirectional2 
Bidirectiona12 
B idirectionall 
Bidirectional2 
3-state 
3-state 
3-state 
3-state 


Extended 
Output 
Output 
0 
Input 
Address8 
3-state 
3-state 


Status 
Output 
Output 
InputlO 
0 
3-state 
3-state 


R/W 
Output 
Output 
Input 
Input 
3-state 
3-state 


B/W9 
Output 
Output 
Input3 
Input-- 


WAIT 
Input 
Input 
Output8 
Output8 


Open Drain 
Open Drain 


AS 
Output 
Output 
Input 
Input 
3-state 
! 3-state 


DS 
Output 
Output 
Input 
Input 
3-state 
3-state 


CS4 
0 
0 
Input 
Input 


RESET 
Input 
Inputl3 
InputS 
0-- 


BUSREQ 
Input 
Bidirectional 
0 
0 
Open Drain 


BUSACK 
Output 
0 


BAfl 
0 
Input 


BA07 
0 
Output 


INT 
Input 


INTACK6 
0 


IEI7 
0 


IE07, 
0 


MMRQ12 
OutQut 
Open Drain 


MMST12 
Input 


MMAI7,12 
Input 


MMA07,12 
Output 


1. Only ADO-AD7' unless peripheral is 16-Bit. 
2. For an 8-bit bus, only ADO':AD7 are bidirectional. 
3. Only for a 16-bit peripheral. 
4. Derived signal, one for each peripheral or memory; decoded 
from status and address lines. 
5. Optional-peripherals are typically reset by AS and i5S being 
Low simultaneously; however, they 'can have a reset input. 
6. Derived signal; decoded from status lines. 
7. Daisy-chain lines. 


Table I. Z-BUS Component Connections to 
Signal Lines. This table shows how the 
various Z-BUS components attach to each 
signal line. When a device is both a bus 


0 


0 


0 


0 


0 
0 


0 
0 


0 
0-- 


Output 
'Open Drain 
0 


Inputll 
0 


Input 
0 


Output 
0 


8. Optional signal(s). 
9. For 16-bit data bus only. 
10. Optional-usually only input on peripherals that are also 
requesters. 
II. May be omitted if peripheral inputs status lines. 
12. Optional signal; any component may attach to the resource 
request lines. 
13. Optional signal; a bus~requestor may also be reset by As and 


OS going Low and BAl being High simultaneously. 
o No Connection 


requester and a peripheral, the attributes in 
both columns of the table should be combined 
(e.g., input combined with output and 3-state 
becomes bidirectional and 3-state.) 


Signal 
Lines 
(Continued) 


Interrupt Signals. These signals are used for 
interrupt requests and for determining which 
interrupting component is to respond to an 
acknowledge. To support more than one type 
of interrupt, the lines carrying these signals 
can be replicated. (The Z8000 CPU supports 
three types of interrupts: non-maskable, vec- 
tored, and non-vectored.) 


INT. Interrupt (active Low). This signal can 
be driven by any peripheral capable of gener- 
ating an interrupt. A Low on INT indicates that 
an interrupt request is being made. 


INTACK. Interrupt Acknowledge (active 
Low). This signal is decoded from the status 
lines. A Low indicates an interrupt acknowl- 
edge transaction is in progress. This signal 
is latched by the peripheral on the rising 
edge of AS. 
lEI, lEO. Interrupt Enable In, Interrupt Enable 
Out (active High). These signals form the 
interrupt daisy chain. 


Resource Request Signals. These signals are 
used for resource requests. To manage more 
than one resource, the lines carrying these 
signals can be replicated. (The Z8000 supports 
one set of resource request lines.) 


MMRQ. Multi-Micro Request (active 
Low). This line is driven by any device that 
can use the shared resource. A Low indicates 
that a request for the resource has been made 
or granted. 
MMST. Multi-Micro Status (active Low). This 
pin allows a device to observe the value of the 
MMRQ line. An input pin other than MMRQ 
facilitates the use of line drivers for MMRQ. 
MMAI, MMAO. Multi-Micro Acknowledge In, . 
Multi-Micro Acknowledge Out (active 
Low). These lines form the resource-request 
daisy chain. 


Transactions 
All transactions start with Address Strobe 
bus master makes ADo-AD15 inactive before 
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being driven Low and then raised High by the 
bus master (Figure 2). The Status lines are 
valid on the rising edge of Address Strobe and 
indicate the type of transactions being initi- 
ated. If the transaction requires an address, 
it must also be valid on the rising edge 
of Address Strobe. 
F or all transactions except null transactions 
(which do nothing beyond this point), data is 
then transferred to or from the bus master. The 
bus master uses Data Strobe to time the move- 
ment of data. For a read (R/W = High), the 


CLOCK 


. driving Data Strobe Low so that the 
addressed memory or peripheral can put its 
data on the bus. The bus master samples this 
data just before raising Data Strobe High. For 
a write (R/W = Low), the bus master puts the 
data to be written on ADo-AD15 before forcing 
Data Strobe Low. 
For an 8-bit Z-BUS, data is transferred on 
ADo-AD7. Address bits may remain on 
ADs-AD15 while DS is Low. 


/ '-----7 BUS MASTER/ "'--- 
BUS MASTER 
SAMPLES 
SAMPLES WAIT 
INPUT DATA 


STO-ST3 


R/W, D/W ___ -+-_ '"------+--------f .f~-----__t-- '-__ _ 


ADo-AD15 


ADO-AD15 


ADDRESS FROM 
BUS MASTER 
DATA TO 
BUS MASTER 


DATA FROM BUS MASTER 
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Memory 
Transactions 
For a memory transaction, the Status lines 
distinguish among various address spaces, 
such as program and data or system and nor- 
mal, as well as indicating the type of trans- 
action. The memory address is put on 
ADo-AD15 and on the extended address lines. 
For a Z-BUS with 16-bit data, the .memory is 
organized as two banks of eight bits each 
(Figure 3) .. One bank contains all the upper 


Ao-A15 


EXTEtlDED 
ADDRESS 


bytes of all the addressable 16-bit words. The 
other bank contains all the lower bytes. When 
a single byte is written (R/W = Low, 
B/W = High), only the bank indicated by 
address bit Ao is enabled for writing. 
For a Z-BUS with 8-bit data, the memory is 
organized as one bank which contains a'll 
bytes. This bank always inputs and outputs its 
data on ADo-AD7. 


1C1·DIT Z·I:lUS DATA PATH 
D 


LOWER 
BANK 
--t:==:::!::==L./----------' ENABLE 


Figuro 3. By to/Word Momory Organization 


1/0 
I/O transactions are similar to memory 
Transactions 
transactions with two important differences. 
The first is that I/O transactions take an extra 
clock cycle to allow for slow peripheral oper- 
ation. The second is that byte data (indicated 
by B/W High on a 16-bit bus) is always trans- 


Null 
The two kinds of null transactions are dis- 
Transactions 
tinguished by the Status lines: internal oper- 
ation and memory refresh. Both tranflar.tions 
look like a memory read transaction except 
that Data Strobe remains High and nodata is 
transferred. 
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For an internal operation transaction, the 
Address lines contain arbitrary data when 
Address Strobe goes High. This transaction is 
initiated to maintain a minimum transaction 
rate when a bus master is doing a long internal 


mitted on ADo-AD7, regardless of the I/O 
address. (ADB-AD15 contain arbitrary data in 
this case.) For an I/O transaction, the address 
indicates a peripheral and a particular register 
or function within that peripheral. 


operation (to support memories which generate 
refresh cycles from Address Strobe). 
For a memor}T refresh trannaction, the 


. Address lines contain a refresh address when 
Address Strobe goes High. This transaction is 
used to refresh a row of a dynamic memory. 
Any memory or I/O transaction can be sup- 


pressed (effectively turning it into a null trans- 
action) by keeping Data Strobe High through- 
out the transaction. 
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Interrupts 
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A complete interrupt cycle consists of an 
interrupt request followed by an interrupt- 
acknowledge transaction. The request, which 
consists of INT pulled Low by a peripheral, 
notifies the CPU that an interrupt is pending. 
The interrupt-acknowledge transaction, which 
is i~itiated by the CPU as a result of the 
request, performs two functions: it selects the 
peripheral whose interrupt is to be acknowl- 
edged, and it obtains a vector that identifies 
the selected device and cause of interrupt. 


A peripheral can have one or more sources 
of interrupt. Each interrupt source has three 
bits that control how it generates interrupts. 
These bits are an Interrupt Pending bit (IP), 


and Interrupt Enable bit (IE), and an Interrupt 
Under Service bit (IUS). 
. 
A peripheral may also have one or more 
vectors for identifying the source of an inter- 
rupt during an interrupt-acknowledge trans- 
action. Each interrupt source is associated with 
one interrupt vector and each interrupt vector 
can have one or more interrupt sources associ- 
ated with it. Each vector has a Vector Includes 
Status bit (VIS) controlling its use. 
Finally, each peripheral has three bits for 
controlling interrupt behavior for the whole 
device. These are a Master Interrupt Enable 
bit (MIE), a Disable Lower Chain bit (DLC), 
and a No Vector bit (NV). 


INTERRUPT 
IIlTERRUPT 


ACo-AC, 


AS 
Z·DUS 
os 
CPU 
iNr 


WAIT 


STATUS 
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VECTOR 
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Figure 4. Interrupt Connections 
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Peripherals are connected together via an 
interrupt daisy chain formed with their lEI and 
IEO pins (Figure 4). The interrupt sources . 
within a device are similarly connected into 
this chain with the overall effect being a daisy 
chain connecting the interrupt sources. The 
daisy chain has two functions: during an 
interrupt-acknowledge transaction, it deter- 
mines which interrupt source is being 
acknowledged; at all other times it determines 
which interrupt sources can initiate an inter- 
rupt request. 
Figure 5 is a state diagram for interrupt 
processing for an interrupt source (assuming 
its IE bit is 1). An interrupt source with an 
interrupt pending (IP = 1) makes an interrupt 
request (by pulling INT Low) if, and only if, it 
is enabled (IE = 1, MIE = 1), it does not have 
an interrupt under service (IUS = 0), no 
higher priority interrupt is being serviced 
(IEI = High), and no interrupt-acknowledge 
transaction is in progress (as indicated by 
INTACK at the last rising edge of AS). IEO is 
not pulled down by the interrupt source at this 
time; lEO continues to follow IEI until an 
interrupt-acknowledge transaction occurs. 


S~me time after INT has been pulled Low, 
the CPU initiates an interrupt-acknowledge 
transaction (indicated by INTACK Low). 
Between the rising edge of AS and the falling 
edge of DS, the IEIIIEO daisy chain settles. 
Any interrupt source with an interrupt pending 
(IP = 1, IE = 1, MIE = 1) or under service 
(IUS = 1) holds its IEO line Low; all other 
interrupt sources make IEO follow IEI. When 
DS falls, only the highest priority interrupt 
source with a pending interrupt (IP = 1) has 
its IEI input High, its IE bit set to 1, and its 
IUS bit set to O. This is the interrupt source 
being acknowledged, and at this point it sets 


its IUS bit to 1, and, if the peripheral's NV bit 
is 0, identifies itself by placing the vector on 
ADo-AD7. If the NV bit is 1, then the periph- 
eral's ADo-AD7 pins remain floating, thus 
allowing external circuitry to supply the vec- 
tor. (All interrupts, including the Z8000's non- 
vectored interrupt, need a vector for identify- 
ing the source of an interrupt.) If the ,vector's 
VIS bit is 1, the vector will also contain status 
information further identifying the source of 
the interrupt. If the VIS bit is 0, the vector 
held in the peripheral will be output without 
modification. 


While an int~rrupt source has an interrupt 
under service (IUS = 1), it prevents all lower 
priority interrupt sources from requesting 
interrupts by forCing IEO Low. When interrupt 
servicing is complete, the CPU must reset the 
IUS bit and, in most cases, the IP bit (by 
means of an I/O transaction). 
A peripheral's Master Interrupt Enable bit 
(MIE) and Disable Lower Chain bit (DLC) can 
modify the behavior of the peripheral's inter- 
rupt sources in the following way: if the MIE 
bit is 0, the effect is as if every Interrupt 
Enable bit (IE) in the peripheral were 0; thus 
all interrupts from the periphera.l are disabled. 
If the DLC bit is 1, the effect is to force the 
peripheral's lEO output Low, thus disa'bling all 
, lower priority devices from initiating interrupt 
requests. 


Polling can be done by disabling interrupts 
(using MIE and DLC) and by reading per- 
ipherals to detect pending interrupts. Each 
Z-BUS peripheral has a single directly 
addressable register that can be read to deter- 
mine if there is an interrupt pending in the 
device and, if so, what interrupt source 
it is from. 
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LOW 
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c¢ 
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C¢ 
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STATE 8 


Figure 5. State Diagram for an Interrupt Source 


Transition Legend 
fA\. The peripheral detects an interrupt condition and sets 
t::/' Interrupt Pending. 


FB'All higher priority peripherals finish interrupt se'rvice, 
t.::/' thus allowing lEI to go High. 


rc"'An interrupt-acknowledge transaction starts, and the 
~ 
IEIIIEO daisy chain settles. 


[£> The interrupt-acknowledge transaction terminates with 
the peripheral selected. Interrupt Under Service (IUS) 
is set to 1, and Interrupt Pending (IP) mayor may not 
be reset. 


rE'The interrupt-acknowledge transaction terminates with a 
~ 
higher priority device having been selected. 


rf'. The Interrupt Pending bit in the peripheral is reset by 
l!:,/ an I/O operation. 
[Q> A new interrupt condition is detected by the peripheral, 
causing IP to be set again. 
, 
fH'.. Interrupt service is terminated for the peripheral by 
LV'resetting IUS. 
lE> IE is reset to zero, causing interrupts to be disabled. 
IE> IE is set to one, re-enabling interrupts. 


1. This diagram assumes MIE = 1. The effect of MIE = 0 is the 
same as that of setting IE = O. 


2. The DLC bit does not affect the states of individual interrupt 
sources. Its only effect is on the IEO output of a whole peripheral. 


State Legend 


No interrupts are pending or under service for this 
peripheral. 


An interrupt is pending, and an interrupt request has 
been made by pulling INT Low. 


An interrupt is pending, but no interrupt request has 
been made because a higher priority peripheral has an 
interrupt under service, and this has forced IEI Low. 


An interrupt-acknowledge sequence is in progress, and 
no higher priorify peripheral has a pending interrupt. 


An interrupt-acknowledge sequence is in progress, but 
a higher priority peripheral has a pending interrupt, 
forcing lEI Low. 


IIJ the peripheral has an interrupt under service. Service 
may be temporarily suspended (indicated by lEI going 
Low) if a higher priority device generates an interrupt. 


This is the same as State 5 except that an interrupt is 
also pending in the peripheral. 


Interrupts are disabled from this source because IE 


Interrupts are disabled from this source and lower 
priority sources because IE = 0 and IUS = 1. 


o. 


3. Transition I to state 6 or 7 can occur from any state except 3 or 
4 {which only occur during interrupt acknowledge}. 
4. TranSition J from state 6 c;>r 7 can be to any state except 3 or 4, 
depending on the value of IEI, IP, and IUS. 
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Figure 6. Bus Request Mechanism States 


Bus Requester Legend 


[DRequester does not want bus and is not pulling 


BUSREQ Low. 
. 


r2'>Requester mayor may not want bus; it is pulling 


a..=,;' BUSREQ Low in either case. 


rp.Requester is not pulling BUSREQ Low; it it wants 
~control of the bus, it must wait for BUSREQ and 
BAI to rise before requesting the bus. 


'4'Requester is either using the bus or propagating . 
U/"the Low on its BAI input. It will stop driving 


BUSREQ when its BAO output goes Low. If it 
wants to use the bus, but did not want to at the 
time BUSREQ arid BAI were last High or BUSREQ 
went from Low to High, then it must wait for 
BUSREQ and BAI to rise before requesting and 
using the bus .. 


IS'Requester is not pulling BUSREQ Low. If it wants 
t:!.I"to use the bus, it must wait for its BAI to become 
High before requesting the bus. 


. f6'Requester is propagating the High on its BAY _ 


~iriput. If it wants the bus it will pull BUSREQ Low. 


~equester is propagating the High on its BAI 


. input.. 
. 


rtJtequester is not· pulling BUSREQ Low. If it ~anted 
o/the bus at the time BUSREQ went from Low to 


High, it may request the bus when its BAI input 
rises; otherwise if it wants the bus, it must wait for 
BUSREQ to rise. 


Bus State Legend 
m 
The CPU owns the bus and no one is ;equesting it. 
rn A bus requester has requested the bus by pulling 


BUSREQ Low, but the CPU has nor responded. 


[]] A Low from the CPU's BUSACK is propagating 
down the BAIIBAO daisy chain. Bus requesters are 
using the bus. 
. 
------- 
m 
The Low from BUSACK has propagated to the end 
of the daisy chain causing all bus requesters to 
release BUSREQ, which floats High. The CPU has 
not yet acknowledged return of the bus. 


=== 
[[] The CPU acknowledges the High on BUSREQ with 
a High on BUSACK, which has propagated down 
the BAIIBAO daisy chain. 


[§] Some device whose BAi input is High requests the 
bus by pulling BUSREQ Low. The CPU has not yet 


. responded with a Low on BUSACK. 
m 
The CPU has responded to a Low on BUSREQ with 


. 
a Low on BUSACK. The previous High state on 
BUSACK is still propagating. down the BAIIBAO 
daisy chain. 
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Bus 
Requests 


Transition Legend 


A A bus requester requests the bus by pulling down 
on BUSREQ. 


B The CPU reponds to BUSREQ by pulling down 


BUSACK. 


C The Low from BUSACK propagates to the end of 
the BAIIBAO daisy chain, causing all the bus re- 
questers to let BUSREQ rise. 


Figure 7 shows how the bus request lines 
connect bus requesters and the CPU on a 
Z-BUS. Figure 8 shows the states of the bus 
request mechanism as the Z-BUS is acquired, 
used, and released. 
To generate transactions on the bus, a bus 
requester must gain control of the bus by 
making a bus request. This is done by pulling 
down BUSREQ . A bus request can be made in 
either of two cases: 


II BUSREQ is initially High and BAI is High, 
indicating that the bus is controlled by the 
CPU and no other requester is requesting 
the bus. 


iii BAI is High and the requester had wanted 
to request the bus at the time of the last 
Low-to-High transition of BUSREQ . This 
insures that a module will not be locked out 
indefinitely by a higher priority bus 
requester. 


After BUSREQ is pulled Low, the Z-BUS 
CPU relinquishes the bus and indicates this 
condition by making BUSACK Low. The Low 
on BUSACK is propagated through the 
BAIIBAO daisy chain (Figure 7). BAI follows 
BAO for components not requesting the bus, 
and any component requesting the bus holds 
its BAO High, thereby locking out all lower 
priority requesters. A bus requester gains con- 


BUS 
REQUESTORS 


Z·BUS CPU 


+5V 


Figure 7. Bus Request Connections 


D The CPU responds to BUSREQ High by driving 


BUSACK High. 


E The High fromB 
--..... 
U--SR--E-Q-- propagates to the end of 
the BAIIBAO daisy chain. 


trol of the bus when its BAI input goes Low. 
When it is ready to relinquish ,the bus, it stops 
pulling BUSREQ Low and allows BAO to 
follow BAI. This permits lower priority devices 
that made simultaneous requests to gain con- 
trol of the bus. When all Simultaneously 
requesting devices have relinquished the bus, 
and the Low on BAIIBAO has propagated to 
the lowest priority requester, BUSREQ goes 
High, returning control of the bus to the CPU. 


The CPU responds to the High on 


BUSREQ' by driving BUSACK High. The High 
on BUSACK is propagated down the BAIIBAO 
daisy chain, thus allowing bus requesters to 
make new bus requests. Because high priority 
bus requesters can pull BUSREQ Low before 
low priority devices have a High on BAI, a 
way is needed for low priority devices to 
request the bus when BUSREQ is Low. That is 
prOVided by the rule that a requester may 
request the bus if BAI is High and it had 
wanted the bus at the time the last Low-to-High 
transition on BUSREQ . 
As soon as BUSREQ is pulled Low by any 
requester, each of the other requesters on the 
bus drives BUSREQ Low and continues to do 
so until it drives its BAO output Low. This pro- 
vides a handshake between the CPU and the 
bus requesters by ensuring that BUSREQ will 
not go High until the CPU's acknowledgement 
of BUSACKhas reached ever'{ requester. Bus 
requesters can therefore run asynchronously to 
the CPU. This rule also allows the bidirectional 
BUSREQ line to be buffered using the logic 
shown in Figure 8. Thi~ logic is similar to the 
logic inside a bus requester ,that keeps 
BUSREQ Low when it has initially been 
pulled Low by a different requester. 


+ 5 V --"N\r--..-.... 


COMMON iiUSREQ 


Figure 8 .. Bus Request Line Buffering 
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Resource 
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Resource requests are used to obtain control 
of a resource that is 'shared between several 
users. The resource can be a common bus, a 
common memory or any other resource .. The 
requestor can be any component capable of 
implementing the request protocol. 
Unlike the Z-BUS itself, no component has 
control of a general resource by default; every 
device must acquire the resource before using 
it. All devices sharing the general resource 
drive the MMRQ line (Figure 9). When Low, 
the MMRQ line indicates that the resource is 
being acquired or used by some device. The 
MMST pin allows each device to observe the 
state of the MMRQ line. 


When MMRQ is High, a device may initiate 
a resource request by pulling MMRQ Low 
(Figure 10). The resulting Low on MMRQ is 
propagated through the MMAI/MMAO daisy 
chain. If a device is not requesting the 
resource, its MMAO output follows its MMAI 
input. Any device making a resource 
request forces its MMAO output High to deny 
lise of the resource to lower priority devices. 
A device gains control of the resource if its 
MMAI input is Low (and its MMAO output is 
High) after a sufficient delay to let the daisy 
chain settle. If the device does not obtain the 
resource after this short delay, it must stop 
pulling MMRQ Low and make another request 
at some later time when MMRQ is again High. 
When a device that has gained cont~ol of a 
resource is finished, it releases the resource by 
allowing MMRQ to go High. 
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MMAI \-.----------4 


MMST I ... -------~ 


MMRO 1-_------4 


MMAO 


MMAI 


MMST I ... -------~ 
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MMST .... ----------4 
MMRO 
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I 
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Figure 9. Resource Request Connections 


Th~ four unidirectional lines of the resource 
request chain allow the use of line drivers, 
thus facilitating connection of components 
separated by some distance. In the case of the 
Z8000 CPU, the four resource request lines 
may be mapped into the cpuMf and MO pins 
using the logic shown in Figure 11. With this 
configuration, the Multi-Micro Request Instruc- 
tion (MREQ) performs a resource request. 


YES 


Figure 10. Resource Request Protocol 


1. For any resource requested, this wait time must be less than the 
minimum wait time plus resource usage time 01 all other 
requesters. 


~--------------~MMST 
Mi----« 


Hf--t.>-------- MMRQ 


MO~----------------~ 
---L-yl------- MMAO 


Figure 11. Bus Request Logic for Z8000 


Test 
Conditions 


DC 
Charac- 
teristics 


Capacitance 


Timing 
Diagramll 


8085·004, 005 


The timing characteristics given in this 
document reference 2.0 V as High and 0.8 V 
as Low. The following test load circuit is 
assumed. The effect of larger capacitive 
loadings can be calculated by delaying output 
signal transitions by 10 ns for each additional 
50 pF of load up toa maximum 200 pF. 


The following table states the dc character~ 


istics for the input and output pins of Z-BUS 


Symbol 
Parameter 


VIL 
Input Low Voltage 


VIH 
Input High Voltage 


VIHRESET 
Input High Voltage on RESET pin 


VOL 
Output Low Voltage 


VOH 
Output High Voltage 


IlL 
Input "Leakage Current 


10L 
3-State Output Leakage Current in Float 


The following table gives maximum pin 
capacitance for Z-BUS components. Capaci- 
tance is specified -at a frequency of 1 MHz 
over the temperature range of the component. 
Unused pins are returned to ground. 


The folloWing diagrams and tables give the 
timing for each kind of transaction (except null 
transactions). Timings are given separately for 
bus masters and for peripherals and memories 
and are intended to give the minimum timing 
requirements which a Z-BUS component must 
meet. An individual component will have more 
detailed and sometimes more stringent timing 
specifications. The differences between bus 
master timing and peripheral and memory tim- 
ing allow for buffer and decoding circuit 


+5V DC 


+5VDC 


'"." ."""' . T '" 


UNDER TEST 1 r 
50pF 


Open-Drain Tost Load 
Standard Tost Load 


components. All voltages are relative to 
ground. 


Min 
Max 
Unit 
Test Condition 


-0.3 
0.8 
V 
2.0 
Vee +0.3 
V 


2.4 
Vee to 
V 
0.3 
0.4 
V 
10L = 2.0mA 


2.4 
V 
10H = 250/LA 


-10 
+10 
/LA 
VIN = 0.4 to 2.4 V 


-10 
+10 
/LA 
VOUT = 0.4 to 2.4 V 


2.2K 


Symbol 
Parameter 
Max (pF) 


CIN 
Input Capacitance 
10 


COUT 
Output Capacitance 
15 


·Cvo 
Bidirectional Capacitance 
15 


delays and for signal skew. The timing given 
for memories is a constraint on bus-compatible 
memories (like the Z6132 Quasi-Static RAM) 
and is not intended to constrain memory sub- 
systems constructed from conventional com- 
ponents. 
Besides these timings, there is a requirement 
that at least 128 transactions be initiated in any 
2 ms period. This accommodates IJ1emories that 
generate refresh cycles from Address Strobe. 


753 


~ 
t':3 
eJ 
(il 


Bus Master 
Timing 


I/O Transaction 
Timing 


Interrupt 
Acknowledge 
Timing 


754 


CLOCK 


STo-ST3 
R/W,B/W 


os 


(READ) 


EXTENDED 
ADDRESS 


ADo-AD15 


os 
(WRITE) 


ADo-AD15 


CLOCK 


ADo-AD15 


ADO-AD15 


CLOCK 


STATUS 


ADo-AD15 


) 
t~ 
------(i)-- 
~l --®--I ) 


---.I 
N- 
J 
) r---'-. " 
'r- 
-~(i}--I-{j)---~I 


SAMPLED 
WAIT CYCLES ! 


CD-- -- 
- 
-+-<D 


ADDEO 
i 
~ --~ 
X 
@--- --<D- --@j-- 
~l 
-------®- 
I-®--i---@~ ·l@).. 
--®--~ 
---@-i---- 
-I -® 
I 
• 
@ 
• 
. 
® -I®: 


...:.~ 
+-®-- 


. 
® 
. 


@----®- ----®---- 
)( 
ADDRESS FROM 
DATA TO 
H 
BUS MASTER 
BUS MASTER 


-----®--- 
~ 
~ 
-®--- 
J-~ 
-®--- 
-®----- 
. 
® 
. 


'X 


DATA FROM BUS MASTER 


Parameters 1-25 are common to all transactions. 
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1-----------4GD~------~~1 


_____________ ®_52=====:~----~ 


T 
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No. 
Symbol 
Parameter 


All Transactions 
1 
TpC 
Clock Period 


2 
TwCh 
Clock High Width 
3 
TwC1 
Clock Low Width 


4 MHz 
Min 
Max 


250 
105 
105 


2000 


6 MHz 
Min 
Max 


165 
70 
70 


2000 


4 
TfC 
Clock Fall Time 
20 
10 


Notes*t 


5- TrC 
Clock Rise Time ----------------- 20 ------15 ------ 
6 
TdC(S) 
Clock t to Status Valid Delay 
110 
85 
7 
TdC(ASr) 
Clock' to AS t Delay 
90 
80 


8 
TdC(ASf) 
Clock t to AS , Delay 
80 
60 


9 
TdS(AS) 
Status Valid to AS t Delay 
50 
30 
10-TwAS 
AS Low Width -------------- 80 ------55--------- 
11 
TdDS(S) 
DS t to Status Not Valid Delay 
75 
55 
12 
TdAS(DS) 
AS t to DS , Delay 
80 
2095 
55 
3 
13 
TsDR(C) 
Read Data !2.-Clock' Setup Time 
30 
20 


14 
TdC(DS) 
Clock' to DS t Delay 
70 
65 


15-TdDS(AS)--DS t to AS , Delay 
70 
35-------- 
16 
TdC(Az) 
Clock t to Address Float Delay 
65 
55 
17 
TdC(A) 
Clock t to Address Valid Delay 
100 
75 
18 
TdA(AS) 
Address Valid to AS t Delay 
50 
35 
19 
TdAS(A) 
AS t to Address Not Valid Delay 
70 
45 
20- TwA 
Address Valid Width ------------ 150 ------85 --------- 
21 
ThDR(DS) 
Read Data to DS t Hold Time 
0 
0 


22 
TdDS(A) 
DS t to Address Active Delay 
80 
45 
23 
TdDS(DW) 
DS t to Write Data Not Valid Delay 
50 
45 
24 
TsW(C) 
WAIT to Clock' Setup Time 
50 
30 
2,4 
25-ThW(C) 
WAIT,to Clock' Hold Time 
10 
10------2,4- 


_ 
__ Memory Transactions 
26 
TdAS(W) 
AS t to WAIT Required Valid 
90 


27 
TdC(DSR) 
Clock' to DS (Read) , Delay 
120 


28 
TdDSR(DR) 
DS (Read) , to Read Data Required Valid 
200 


45 
85 
130 


29 
TwDSR 
DS (Read) Low Width 
250 
185 
30-TdA(DS)-'--Address Valid to DS , Delay---------180 ------110--------- 
31 
TdAz(DSR) 
Address Float to DS (Read) , Delay 
0 
0 


32 
TdAS(DR) 
AS t to Read Data Required Valid 
33 
TdA(DR) 
Address Valid to Read Data Required Valid 
34 
TdC(DSW) 
Clock! to DS (Write) , Delay 


360 
410 
95 


220 
305 
80 


35-TwDSW 
DS (Write) Low Width-----------160 ------110--------- 
36 
TdDW(DSWf) 
Write Data Valid to DS (Write) , Delay 
50 
35 
37 
TdDW(DSWr) 
Write Data Valid to DS (Write) t Delay. 
230 
195 


I/O Transactions 
38 
TdAS(DR) 
AS t to Read Data Required Valid 
610 
39 
TdA(DR) 
Address Valid to Read Data Required Valid 
660 


385 
470 


40-TdAz(DSl)--Address Float to DS (VO) ,----------0 ------0--------- 
41 
TdC(DSI) 
Clock' to DS (VO) , 
120 


42 
TdDSI(DR) 
DS (VO) , to Read Data Required Valid 
330 


43 
TwDSI 
DS (VO) Low Width 
400 
255 
44 
TdA(DSl) 
Address Valid to DS (VO) , Delay 
180 
110 


90 
210 


45-TdDW(DSIf)--Write Data to DS (I/O) , Delay--------50------35-------- 
46 
TdDW(DSlr) 
Write Data to DS (VO) t Delay 
480 
320 


47 
TdAS(W) 
AS to WAIT Required Valid 
340 
210 


Interrupt-Acknowledge Transactions 
48 
TdAS(DSA) 
AS t to DS (Acknowledge) , Delay 
960 
690 


49 
TdC(DSA) 
Clock t to DS (Acknowledge) , Delay 
120 
85 


50-TdDSA(DR)--DS (Acknowledge) , to Read Data Required Valid ----- 455 ------295 ------ 
51 
TwDSA 
DS (Acknowledge) Low Width 
485 
315 
52 
TdAS(W) 
AS t to Wait Required Valid 
840 
540 


53 
TdDSA(W) 
DS (Acknowledge) , to Wait Required Valid 
185 
120 


NOTES: 
1. Timing for extended addresses is CPU dependent; however, 
extended addresses must be valid at least as soon as addresses 
are valid on ADO-ADlS and must remain valid at least as 
long as addresses are valid on ADO-ADlS. 


2. The exact clock cycle that wait is sampled on depends on the 
type of transaction; however, wait always has the given setup 
and hold times to the clock. 
3. The maximum value for TdAS(DS) does not apply to Interrupt- 


Acknowledge Transactions. 


4. The setup and hold times for WAIT to the clock must be met. 
If WAIT is generated asychronously to the clock, it must be 
synchronized before input to a bus master. 


• Timings are preliminary and subject to change. 
t Units in nanoseconds (ns). 
Except where otherwise stated, maximum rise and fall times for 
inputs are 200 ns. 
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C8014-0183 C8014-0188 C8014-0192 


4MHz 
6 MHz 
No. 
Symbol 
Parameter 
Min 
Max 
Min 
Max 


All Transactions 
1 
TsCS(AS) 
CS to AS I Setup Time 
0 
0 


2 
ThCS(AS) 
CS to AS I Hold Time 
60 
40 


3 
TsS(AS) 
Status to AS I Setup Time 
20 
0 


4 
ThS(DS) 
Status to DS I Hold Time 
55 
40 


5-TsA(AS) --- Address to AS I Setup Time 
30 
10 
6 
ThA(AS) 
Address to AS I Hold Time 
50 
30 


7 
TwAS 
AS Low Width 
70 
50 
0 


8 
TdDS(DR) 
DS I to Read Data Not Valid Delay 
0 


9 
TdDS(DRz) 
DS I to Read Data Float Delay 
70 
45 
lO-TdAS(DS)-- AS I to DS 1 Delay 
60 -2095,-- 40 


11 
TdDS(AS) 
DS I to AS 1 Delay 
50 
25 
12 
ThDW(DS) 
Write Data to DS I Hold Time 
30 
20 


Memory Transactions 
13 
TdA(DR) 
Address Required Valid to Read Data Valid Delay 
320 
255 
14 
TdAS(DR) 
AS I to Read Valid Delay 
270 
170 


15-TdAz(DSR) -- Address Float to DS (Read) 1 Delay 
0 
0 


16 
TdDSR(DR) 
DS (Read) 1 to Read Data Valid Delay 
110 
80 


17 
TwDSR 
DS (Read) Low Width 
240 
180 


18 
TdA(DS) 
Address to DS 1 Setup 
160 
100 


19 
TwDSW 
DS (Write) Low Width 
150 
105 


20 
TsDW(DSWf) 
Write Data to DS (Write) 1 Setup Time 
30 
20 


21-TsDW(DSWr)-Write Data to DS (Write) I Setup Time 
210 
180 
1/0 Transactions 
22 
TdA(DR) 
Address Required Valid to Read Data Valid Delay 
570 
420 


23 
TdAS(DR) 
AS I to Read Data Valid Delay 
520 
335 
24 
TdDSI(DR) 
DS (Va) 1 to Read Data Valid Delay 
250 
180 


25 
TdAz(DSI) 
Address Float to DS (Va) 1 Delay 
0 
0 


26-TdA(DSI)--Address to DS (Va) 1 Setup 
160 
100 


27 
TwDSI 
DS (Va) Low Width 
390 
250 


28 
TsRWR(DSI) 
RlYJ.. (Read) to DS (Va) 1 Setup Time 
100 
100 


29 
TsRWW(DSI) 
RIW (Write) to DS (I/O) 'I Setup Time 
0 
0 
30 
TsDW(DSIf) 
Write Data to DS (Va) 1 Setup Time 
30 
20 


31 
TsDW(DSlr) 
Write Data to DS (I/O) I Setup Time 
460 
305 


32-TdAS(W)--AS I to WAIT Valid Delay 
195 
160 


Interrupt-Acknow ledge Transactions 
33 
TsIA(AS) 
INTACK to AS I Setup Time 
0 
0 


34 
ThIA(AS) 
INTACK to AS I Hold Time 
250 
250 


35 
TdAS(DSA) 
AS I to DS (Acknowledge) 1 Delay 
940 
675 
36 
TdDSA(DR) 
DS (Acknowledge) 1 to Read Delay Valid Delay 
365 
245 
37-TwDSA 
DS (Acknowledge) Low Width 
475 
310 
38 
TdAS(IEO) 
AS 1 to IEO 1 Delay 
39 
TdIEIf(IEO) 
IEI to lEO Delay 


40 
TsIEI(DSA) 
lEI to DS (Acknowledge) 1 Setup Time 


NOTES: 
I. Parameter does not apply to Interrupt Acknowledge Trans- 


actions. 
higher priority peripheral, and TdIEIf(IEO) for each peripheral 


2. Does not cover R/W for I/O Transactions. 
3. Applies only to a peripheral which is pulling INT Low at the 
beginning of the Interrupt Acknowledge Transaction. 
4. These parameters are device dependent. The parameters for the 
devices in any particular daisy chain must meet the following 
constraint: for any two peripherals in the daisy chain, 
TdAS(DSA) must be greater than the sum of TdAS(IEO) for the 


00·2031-02 


separating them in the daisy chain. 
' 
5. The maximum value for TdAS(DS) does not apply to Interrupt 
Acknowledge Transactions . 


• Timings are preliminary and subject to change. 
t Units in nanoseconds (ns). 
Except where otherwise stated, maximum rise and fall times for 
inputs are 200 ns. 
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[J The bus structure for the SO's 


[] Compatible with the Z-BUS Component 
Interconnect system ' 


[] Designed for the powerful Zilog Family of 
Microprocessors 
o Z8 CPU 
o Z80 CPU 
o Z8000 CPU 
o Future microprocessors 


o Flexibility in application 
o 8-, 16- or 32-bit operations 
o Unsegmented, segmented, or memory 
mapped systems 


[J Future growth 
o Allows 32-bit operations 
o 5-bit status field 


The Z-BUS Backplane Interconnect (ZBI) 


system is a high performance, application- 
oriented system bus designed to utilize the full 
capabilities of all Zilog. microprocessors-the 
Z8, Z80 and Z8000. 


Thirty-two address/data lines coupled with 
twenty-eight control lines provide the 
resources needed for growth paths to future, 
more complex 32-bit microprocessors. 
A member of the Z-BUS family of microcom- 


Mechanical Configuration. The ZBI bus is 
defined for three sizes of modular boards. The 
single size modules measure 6.3" x 3.9" (160 
mm x 100 mm). The double size boards are 
6.3" x 9.2" (160 mm x 233.4 mm), and the 
double extended size measure 11.0" x 9.2" 
(280 mm x 233.4 mm). All ZBI boards are 
consistent with the standard European form 
factor. 
The single size boards have a single bus 
connector while the double boards have two 
connectors. 
The connector has a matrix of 96 pins on 


!18JI 


~lIIlmU~ l!a«:n~plaD1l12 


ilmlftC2)f(cc@numl~3::ft ~~sl~mm 


Ji>ro an nIl ea 
lIDes«!lriipftiicml 


September 1 9S3 


[J Designed-in reliability 
o Byte-oriented parity and parity error line 
o High reliability pin and socket connectors 
o Distributed ground lines 
o High-current power distribution 
o Terminated bus lines 
r.----' 
I 
EXTENDED 
I 
I 
I 


PROCESSORS 
za 
zao 
zaooo 86 


EXPANSION 
PERIPHERAL 
I/O 
ACCESSORIES 
MEMORY 
CONTROLLERS 


puter bus structures, the ZEI bus is compatible 
with the Z-BUS Component Interconnect (ZCI) 
system used for communications at the chip 
level between Zilog processors and their 
peripheral support modules. 
Reliability has been designed into the ZBI 


structure: parity lines have been included; 
ground lines are distributed between signals to 
reduce noise; and all bus lines are terminated. 


.100" (2.54 mm) centers which are aligned in 3 
rows of 32 pins each. A molded plastic housing 
surrounds the pin array, providing mechanical 
rigidity and protecting the pins from' 
mechanical damage. 
The backplanes use a similar style of mating 
connector. These connectors are highly 
reliable because connection surfaGes are com- 
pletely enclosed and shielded from dirt and 
dust when the connectors are mated. Another 
advantage of this connector is its high density 
which permits the design of compact boards. 
In addition, the connectors are self-aligning 
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and keyed to prevent improper insertion. 
All of the signals on the double boards are 
assigned to one connector so that single 
boards can be used in the same backplane 


1 
SINGLE 
6.300 
DOUBLE 
160 1 
h 
I/O SIGNALS 
I/O SIGNALS 


U. 
1 __ 3;~~7_1 
9.187 


233.400 


with double boards. The second connector on 
the double boards is unspecified and available 
for use by the designer. 


I 


UNSPECiFIED .... ---/ 
BI 


11.023 
EXTENDED 
280 


l0.. 
1/0 SIGNALS 
/1 
-= 
~ 


9.187 
233.400 


Figure 2. The ZBI backplane accepts two sizes of boards: both are compatible with 
European standards. The dimensions are in inches (upper) and millimeters (lower). 


The ZBI consists of 96 lines: 32 bidirectional 
address/data lines with four parity lines, nine 
interrupt lines, 28 control lines, 21 power- 
supply lines for ± 12 V, ±5 V and ground and 
two reserve lines. The pin layout was defined 
to provide the most convenient connection 
from the board and the backplane, with signals 
collected into logical groups for placement on 
the connector. 
Address and Data. The address/data group is 
laid out to enable the lines to enter the board 
in order on both two-layer and four-layer 
boards. Low-order lines are placed next to the 
power pins for easier routing through buffers. 
The high-order address/data pins are posi- 
tioned near the control pins to facilitate 
decodjng of the state of the bus. Address and 
data information is transmitted over 32 bidirec- 
tional lines with separate address and data 
strobe lines arbitrating the informati9n flow. 
The use of shared address/data lines enables a 
compact connection while still allowing 32-bit 
word sizes. 
Word size is controlled by two lines that 
indicate the data width of the current opera- 
tion on the bus, making possible 8-bit, 16-bit 
and 32-bit word transfers in the same system. 
Data is aligned in the lower byte (ADo-AD7) of 
the data field for 8-bit transfers, and the lower 
word (ADo-AD15) for 16-bit transfers. 
The ZBI includes four parity lines and an 
error-indication line to detect errors in 
memory devices and transmissions on the bus. 
One parity bit is provided for each byte 6f the 
32-bit address/data field, enabling parity- 
checking at· both the byte and word levels. 
Control Signals. The ZBI bus has 28 lines that 
are used for bus control and status, grouped 
into the following categories: 


• Clocking. Two lines provide a master clock and a bus 
clock. The master clock supplies a constant frequency 


and is used as a master timing reference; the bus clock 
is derived from the master. 


• Extended processor architectures. Two lines enable the 


CPU to interact with an Extended Processor Unit. 


• Resource sharing. Three lines enable processors to 
lock other processors off the bus. This is a software 
implementation, and all processors must be aware of 
these signals for the lockout to be effective. 


• Direct memory access. Three lines provide the control 
signals required for data to be transmitted in burst 
mode across the bus. When a DMA device wants to 
transmit information, it issues a request that causes the 
processor to get off the bus. Once off the bus, the pro- 
cessor issues an acknowledge signal indicating that the 
bus is free. The DMA device then begins transferring 
data to the specified address. When the transfer is com- 
plete, the processor regains use of the bus. 


• Muiltiprocessor. Four lines enable multiple processors 
to share a common bus. (Arbitration logic to prevent 
contention errors must be included on each module.) 


• Data/Address Strobe. Two lines indicate whether 
address or data information is on the address/data lines. 


• Status. Five lines designate the kind of transaction 
occurring on the bus. 


• 
Word-size select. Two lines determine the word size of 
the transaction on the bu~. 


Interrupts. The ZBI bus has three independent 
interrupt groups. Each group has an interrupt 
request line and an interrupt enable input and 
output daisy chain. A different priority level is' 
assigned to each of the three interrupt groups 
and position-dependent priority is assigned to 
each device within the groups. 
The treatment of the interrupt signal is 
processor-dependent and can be maskable, 
non-maskable, vectored, or non-vectored 
depending upon the configuration of the. 
system CPU. 


Bus Conditioning. All bus lines are ter- 
minated in resistor pairs to provide the highest 
integrity and best noise immunity for the 
system. This forces all undriven lines to 
approximately + 3 V. 
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Signal 
Definition 
Table 1 defines the signals necessary to the 


2EI structure. 
All signals, with the exception of the data 
and address lines, are negative true signals, 
where logical 1 = < 0.5 V and logical 
o = > + 2.4 V. Any exceptioI1 to this stan- 
dard is noted in the table. Naming conventions 
are as follows: 


NAME: a single line, n~gative-true logic level 


NAME: a single line, positive.true logic level 


NAME < 0.3>: 4 lines, positive-true logic level 


NAMElINAME2: a doubly named line, 
High/Low logic levels 


The abbreviations used to describe signal 
types are: 


BD: Bidirectional data lines 


TS: 3-state, undirectional lines 


OC: Open collector 
He; High-current driver line, not 3-state 


DC: Daisy-chained Signal-OUT on one board 
connects to IN of the next board 


j" 
Signal 
Number 
Signal 
Type 
Name 
of Lines 
Function 
Address and Data Group -------------------------------------- 
AD<O:3l> 
32 


Parity Group 
P<O:3> 
4 


PE 


Interrupt Group 
INTI 


INT2 


INT3 


IEIl 
IEOI 
IEI2 
IE02 
IEI3 
IE03 


Control Group 
PWRBAD 


BD 


BD 


OC 


OC 


OC 


OC 


DC 
DC 
DC 
DC 
DC 
DC 


OC 


Address and Data Lines. Address and data information is time-multiplexed onto 
these lines. The times they are valid are defined by address strobe (AS) and data 
strobe (DS). Additional information can be derived from the BCLK signal for syn- 
chronous operation. 
" 


Parity-Check Bits. For bus transfer integrity, one parity bit is provided for each 
byte of the 32-bit adqre~s/data bus. Even parity ensures that a read from a non- 
existent resource will generate a parity fault. 
Parity Error. Indicates to the Bus Master that a parity error in a data transfer on 
the bus has been caught by the parity check logic. 


Levell Interrupts. Highest priority interrupt in the system. If a non-maskable 
interrupt is present, it must be here. 
Level 2 Interrupt. Second highest priority interrupt in the system. If a vectored 
interrupt is present, it must be here. 
Level 3 Interrupt. Lowest priority interrupt in the system. If a non-vectored inter- 
rupt is present, it must be here. 
Level'l Interrupt Enable In 
Level 1 Interrupt Enablr Out 
Level 2 Interrupt Enable In 
Level 2 Interrupt Enable Out 
Level 3 Interrupt Enable In 
Level 3 Interrupt Enable Out 


Power Bad, An early warning signal that the dc power for the system will soon 
disappear. This signal is generated by the power supply to give the processor 
enough t~me to store the machine state (if appropriate storage is available) before 
power drops below critical levels. 
Clocking ----------------------~---------------------- 
MCLK 


BCLK 


HC 


HC 


Master ~fpfi:~' Sy:;tem plqster clock-16 to 32 MHz. Frequency is a 4 X multiple of 
the desited1bus clock frequency. 
Bus Clock. Bus transQcttl=))1 cloc~, derived from Master Clock and used by all syn- 
chronous elements in the system. 


Extended Processing Architecture ------.,.-----r-r-----.,--------------------- 
N/S 
1 
TS 
Normal/;;y~.em. Indicates the mode of the CPU controlling the bus-Normal user 


mad~. or Systepl mode (able to execute privileged instructions). 


OC 
Stop pne. Stop the processor in control of the bus for synchronization of activities 
with the C:;PU, 


Address/Data Strobes ---------------------------------------- 
AS 
1 
TS 


TS 


Address Stj:'obe. Indicates that the AD lines contain a valid address. The AS line is 
pulsed ~0':'f by a board controlling the transaction for program or data memory 


acce~~! AQ~n~ss'fl1 pre vql~p at ~he trailing (rising) edge of AS. 
Data Strobe, Data is placed on or accepted from the AD bus lines whe"n DS is low. 


Table 1. SignalO,pniHons 


i ipi 
II' 
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Signal 
Number 
Signal 
Name 
of Lines 
Type 
Function 
Status 
ST<0:4> 
5 
TS 
Status Lines. These lines designate the type of transaction occurring on the bus. 


S, S3 ~ SI So 
Transaction 


0 0 0 0 0 
Internal Operation 
0 
0 
0 
Data Mem < > EPU 
0 0 0 0 
1 
Memory Refresh 
transfer 


0 0 0 
1 0 
VO Reference 
0 
0 
Stack Mem < > EPU 
0 0 0 
1 1 
Special VO 
transfer 


0 0 
1 0 0 
0 0 
1 0 1 


Reference 
0 
0 0 
Prog Ref - nth cycle 


Segment Trap Ack 
0 
0 
1 
Prog Ref - 1 st cycle 
Intl Interrupt Ack 
0 
1 0 
EPU <> CPU 
0 0 
1 1 0 
Int2 Interrupt Ack 
transfer 


0 0 
1 1 1 
Int3 Interrupt Ack 
0 1 1 1 1 
Reserved 


0 
1 0 0 0 
Data Memory 
1 X X X X 
Reserved 


0 
0 0 


Request 


Stack Memory 
Request 


~ord Size Select----------------------------------------------------------------------------------- 
BM 
1 


W/LW 


Resource Sharing 
MMREQ 
1 


MMAI 


MMAO 


Direct Memory Access 
BAI 
1 


BAO 


BUSREQ 


TS 


TS 


OC 


DC 


DC 


DC 


DC 


OC 


Byte/~ord Select. Used in conjunction with W/LW to define data access width. 


~ord/Long ~ord Select. Used in conjunction with BIW to define the data access 
width. (A logical 1 is a high voltage level.) 


B/W 
W/LW 
Access Width 
1 
1 
Byte (8-bit}-Data on AD < 0:7> 
o 
1 
Word (l6-bit}-Data on AD < 0: 15> 
1 
0 
Double Word (32-bit}-Data on AD <0:31> 
o 
0 
Reserved 


Multimicro Request. This is a software request to another processor for software 
synchronization. 
Multimicro Acknowledge In. Forms the logical chain among processors to per- 
form software arbitration, in conjunction with the MMAO signal. The effect of this 
line is dependent on the software present on the processor board. 
Multimicro Acknowledge Out. Completes the logical chain to the next processor's 
MMAI pin. 


Bus Acknowledge In From Priority Chain. This signal and BAO form the bus 
priority chain. 
Bus Acknowledge Out to Priority Chain. Completes the circuit to the next device 
in the bus priority chain. 
. 
Bus Request. Used to request access to the bus. A request to a processor to relin- 
quish the bus at the end of the current instruction cycle. This signal is used with 
the BAI and BAO signals to control bus sharing by DMA devices not able to 
become bus masters. 


Multiprocessor Control ---------------------------------------------------------------------- 
CAl 
1 
DC 


CAc5 
DC 


CPUREQ 
DC 


CAVAIL 
TS 


CPU Acknowledge In. 
CPU Acknowledge Out. 


CPU Request. A request to the processor currently in control of the bus to relin- 
~h control at the end of the current instruction cycle. This signal is used with 
CAl, CAO, and CAY AIL to control sharing of the bus by devices able to become 
bus masters. 
• 


CPU Available. Used in conjunction with CAl and CAO to transfer bus control 
from one bus master to another. 


Miscellaneous Control Lines -----------:--------------------------------------- 
RESET 
1 
OC 


WAIT 
OC 


RIW 
TS 
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Reset. Connected to the master reset switch and power-up reset circuit. 
Wait. Causes a processor or peripheral to wait for the response to a request for 
data. Such a wait could be caused by slow memory or by refresh contention 
problems. 


Read/~rite. 1£ this line is high, the current operation is a read; if low, a write. 


Table 1. Signal Definitions (continued) 


00·1003-01 


Zilog 


General 
Description 


Zilog offers high-reliability versions of the 
entire family of Z8, Z80, and Z8000 logic cir- 
cuits, processed in accordance with the 
requirements of MIL-STD-833 (Test Methods 
and Procedures for Microelectronics). TheZ80 
and Z8000 CPUs are currently Qualified Prod- 
ucts, Level II MIL-M-3851O. 


General Considerations. Zilog high-reliability 
microcircuits are designed to meet the full 
military temperature range of -55°C to 
+ 125°C and are packaged in hermetic dual- 
in-line packages. These packages can reliably 
withstand the thermal shock requirements of 


Test 
Condition 


Precap Visual 


Seal and Lot I.D. 


Stabilization Bake 
48 hrs. @ 150°C 


Temperature Cycling 
10 cycles 


Centrifuge 
Yl Plane 


Fine Leak 


Gross Leak 


Electrical Test 
Per Zilog Data Sheets 


Burn-In 
160 hr. + 8 - 0 


Final Electrical 
-55°C, 


and + 125°C 


External Visual 


NOTES: S = Sample testing only, X = 100% testing. 


BighaReliabilily 
MAciOciii'CWliiQs 


Military Specification 
Standards· 


June 1982 


MIL-STD-833, method 1011, Condition C 
(-65°C to + 150°C). For industrial users, Zilog 
offers an extended operating temperature 
range of-40°C to +85°C. All of Zilog's high- 
reliability microcircuits receive 5004 process- 
ing in accordance with the requirements of 
MIL-STD-833. Table 1 lists the screening tests 
performed on the two levels. An X indicates 
that the test is performed 100% of the time. 
Additional screening options are available 
upon request. Table 2 lists the Zilog products 
available with the 100% testing process shown 
with X's in Table 1. 


MIL-STD-883 
Class 
Method Condition 
B 
C 


2010 
B 
X 
X 


X 
X 


1008 
C 
X 
X 


1010 
C 
X 
X 


2001 
E 
X 
X 


1014 
A 
X 
X 


1014 
C 
X 
X 


X 
X 


1015 
160 hrs. 
X 


X 
X 
X 
X 


2009 
X 
X 


Table 1. Total Lot Screening 
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III - 
G 
~ 
II 
CD = 
II 
cr 
J 


, General 
Description 
(Continued) 


Manufac- • 
turing and 
Process 
Controls 


764 


883 Temp 
Extended 


Product· 
Speed 
Range 
Temp Range 


za611 
8.0 MHz 
Yes 
Yes 


za681 
8.0 MHz 
Yes 
Yes 


zao CPU 
2.5 MHz 
Yes 
Yes 


zaOA CPU 
4.0 MHz 
Yes 
Yes 


zao PIO 
2.5 MHz 
Yes 
Yes 


~OA PIO 
4.0 MHz 
Yes 
Yes 


zao SIO 
2.5 MHz 
Yes 
Yes 


zaOA SIO 
4.0 MHz 
Yes 
Yes 


zao CTC 
2.5 MHz 
Yes 
Yes 


zaOA CTC 
4.0 MHz 
Yes 
Yes 


zaOOl CPU 
4.0 MHz 
Yes 
Yes 


zaOOlA CPU 
6.0 MHz 
Yes 
Yes 


za002 CPU 
4.0 MHz 
Yes 
Yes 


. za002A CPU 
6.0 MHz 
Yes 
Yes 


za030 Z-SCC 
4.0 MHz 
Yes 
Yes 


za030A Z-SCC 
6.0 MHz 
Yes 
Yes 


za036 CIO 
4.0 MHz 
Yes 
Yes 


za036A CIO 
6.0 MHz 
Yes 
Yes 


za038 Z-FIO 
4.0 MHz 
Yes 
Yes 


za038A Z-FIO 
6.0 MHz 
Yes 
Yes 


za530 SCC 
4.0 MHz 
Yes 
Yes 


za530A SCC 
6.0 MHz 
Yes 
Yes 


za536 CIO 
4.0 MHz 
Yes 
Yes 


za536A CIO 
6.0 MHz 
Yes 
Yes 


·;NOTE: See Ordering Information for package and temperature designators .. 


Table 2. High.Rellablllty Products Available 


Zilog high-reliability microcircuits will be 
processed and assembled in accordance with 
the, requirements of Appendix A of MIL- 
M-38510 or MIL STD 883, as specified by 
. customer purchase order. The following are . 


~ome of the items contained in the Zilog Prod- 
uct Assurance Program Plan: 


• A clear, concise procedure for converting a 
customer specification to a Zilog internal 
specification,. assuring the customer that 
parts received meet or exceed specified 
requirements. 


• A formalized training and testing program 
for operators and inspection personnel to 
ensure that each operation is performed 
correctly. 


II An inspection system that includes a com- 


plete Incoming InspE/ctioI')., Laboratory and a 
Chemical Analysis ,I:aboratory ensure' that 


~/f"".r 


all materials, utilities, and work-in-progress 
meet Zilog requirements and specifications. 


• Rigid requirements for the cleanliness of 
work areas and the maintenance of a Class 
100 environment at all stations where 
critical operations are performed. 


• ·A document control system to control 
changes in deSign, materials, and pro- 
cesses. 


• An instrument maintenance and calibration 
program complying to the requirements of 
MIL-STD-45662 (Calibration System 
Requirements) . 


• A quality audit system in accordance. 


with MIL-I-45208 (Quality Program 
Requirements) . 


Zilog offers '1 number of standard flows, 
which include both military and commercial 
temperature ranges (see Table 3). 


Environmental Flow 
A 
B 
Bl 
G 
H 
K 
Q 


Temperature Range 
S,E 
M 
M 
S,E 
S,E 
S,E 
M 


Package 
C,D,L 
C,D,L 
C,D,L 
D,P 
C,D,L,P 
P 
C,L 


Pre-Cap Visual 
Method 2010, 
X 
X 
X 
X 
X 
X 
X 
Condition B 


Stabilization Bake 
Method 1008, 
X 
X 
X 
X 
X 
X 
X 
Condition C 


Temperature Cycle 
Method 1010, 
X 
X 
X 
X 
X 
X 
Condition C 


Centrifuge Method 
2001, Condition E 
X 
X 
X 
(y, axis only) 


Fine and Gross Leak 
II 
Method 1014, 
- 
Condition Fine A2 
X 
X 
X 
X 
9- 
Gross C 


11:1 


100% Electrical Test 
X 
X 
X 
X 
X 
X 
X 
CD = 
III 
Burn-In Method 1015, 
X 
X 
X 
X 
X 
X 
=r 


Condition D 
e 


100% Electrical Test 
X 
X 
X 
X 
X 
X 
X 
q 


QA Test at Temperature 
X 
X 
X 
X 
X 
X 
X 


100% Electrical Test 
X 
X 
X 
X 
X 
X 
X 


Group B/C/D Generic 
X 
X 
Data 


Note: All test methods are per MIL-STD-883. 


Table 3. Standard Flows 


00-2027-03 
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Packaging· 


information 


Zilog 


Pioneering the 
Micro world 


Zil©g' 


m:r:: 


Paclcage 
Information 
This table summarizes the microprocessor 
components available from Zilog by number of 
pins and package type. Following the table are 
detailed drawings for each package type. For 


Pins 
Packago 
Componont 


18 
Ceramic, Cerdip, Plastic 
28581 CGC 


28 
Ceramic, Cerdip, Plastic 
28430 280 CTC 


28 
Leadless Carrier, Ceramic 
28430 280 CTC 


40 
Ceramic, Cerdip, Plastic 
28002 28000 CPU 
28030 28000 Z-SCC 
28036 28000 Z-CIO 
28038 28000 Z-FIO 
28090 28000 Z-UPC 
28400 280 CPU 
28410 280 DMA 
28420 280 PIO 
28440 280 SIO/O 
28441 280 SIO/l 
28442 280 SIO/2 
28449 280 SIO/9 
28470 280 DART 
28530 SCC 
28536 CIO 
28538 FlO 
28590 UPC 
2860128 MCU 
2861128 MCU 
2867128 MCU 
2868128 MCU 


40 
Protopack 
28093 28000 Z-UPC 
28094 28000 Z-UPC 
28593 UPC 
28594 UPC 
2860328 MCU 
2861328 MCU 


• NOTE: As a result of size of package, all three SIO versions are 
Included In one version, the 28444. 


September 1983 


further information on specific components, 
IQ 


see the Ordering Information section of each 
tlJ 


product specification. 
~ 
IZJ 
G ii 
Pins 
Packago 
Component 
G 


44 
Leadless Carrier, Ceramic 
28002 28000 CPU 
[ 


28030 28000 Z-SCC 
0 ... 
28036 28000 Z-CIO 
e 
28038 28000 Z-FIO - 
28400 280 CPU - 
0 
28410 280 DMA 
t1 
28420 280 PIO 
28444 280 SIO· 
28530 SCC 
28536 CIO 


48 
Ceramic, Plastic 
2800128000 CPU 
28010 28000 Z-MMU 


52 
Leadless Carrier, Ceramic 
28010 28000 Z-MMU 
2800128000 CPU 


64 
Ceramic, Plastic 
28015 28000 Z-PMMU 
281162800 MCU 
28216 2800 MCU 
2861228 DM 


68 
Leadless Carrier, Ceramic 
2801528000 Z-PMMU 
28070 APU 
281162800 MCU 
28216 2800 MCU 
28612 Z8 DM 
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Package 
Information 
(Continued) 
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18 
10 


IS-Pin Ceramic Package 


G~~+~ :~ A :~:w: : ~ 


0.320 __ "I 
0.220 ~ V 
V ~ 
MAX 
MiL 
SEALING GLASS 


~35 
0.125 - ::!: .015 
MIN 
l.ooo MAX 


0.100 
::!:.010 


TYP 


IS-Pin Cerdip Package 


£~i~~A2i¥S~ 
: 
: :: 
: 
: :1 


BOTH ENDS 


0.025 
~0.920~ 
o 300 
0.030 
MAX 


r-0:320-1 
0.065~ 
~ -11--0•040 
0.130 
B' Tr~J::£"'4'''' 
O.OO!! 
~ I 
I IJj 
0.015, 
I 
I 


I-~:~~~--l 
0.050 
t- 
~r-- 
0.100--j r 
0.125 
-.015 
::!:.015 
g:g~~ 
TYP 
MIN 


IS-Pin Plastic Package 


NOTE: Package dimensions are given in inches. To convert to millimeters, multiply by 25.4. 


Paclcago 
Information 
(Continued) 


PIN 1 


IDENTIFICATION 


0.185 


28 
15 


14 


lO.110 
0.090 
II 
0.021 
- 
'-0.015 


20-Pln Coramlc Packago 


G~!~~2_8LL~~-LLL~~ULLLLl~-ULL~~1~5-. 


0.550 


l'---r-T-r-T-r-r~~ 


14 
r . 
1,1.':1 
'I 
o 230 
'0.056 
. 


• AXL~ 


o t 
1-1 
I 
0100 "AX 
I 
I 
0.100 
" 
.. 18 
"'IN :J 
t+- B'OTH ENDS~ t+-:.010 
-+It+-:!:.003 
'" 
TYP 
TYP 


0.040 
:.020 


28 


20-Pln Cordlp Packago 


0.100 
TYP 


0.018 
0.050 
: .003 TYP 
TYP 


20-Pln Plastic Packago 


15 


14 
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Package 
Information 
(Continued) 


40 
21 


PIN 1 


IDENTIFICATION 


772 


1~~:--1 


~ 


, 
LJ •. ".t' 
=.002 


TYP 


1---0.600 ----l 


REF 


20 
I' 
2.02' 
MAX 


~~ 5: 


I 
I 
I 
M 


I 
II 


0.125 
0.050 
0.100 
0.018 
MIN 
l =.015 BOTH ENDS 
-l l =.010 TYP 
--J L =.003 TYP 


0.060 
0.020 


40·Pin Ceramic Package 


G~gt 
40 
21 


0.550 


l~~~~,.........,.,.. 


20 
· 
~o:~------------ 


om 
M~ 


. ...11.' lj ~~b~H'!~''bs 
-I ~:f~ 
-I~±"Tgr, 
0.040 
=.020 


40·Pin Cerdlp Packago 


NOTE: Package dimensions are given In Inches. To convert to millimeters, multiply by 25.4. 


Package 
Information 
(Continued) 


40 
21 
T 
0.555 


:r:~~~=rrT~~n=rrTT~=nrr~~~n=rrTT,,=rrr~~ 


20 


I 
'~--------------------~~----------------------~"I 
r---0.620 ------1 
0.150 
,~0.600~, 
MAX 


at ~ 
= 
)~ Ji:-=------H-------I~~O 


+0.009 
~ 
I. 
0.650 
.1 
r----0.610~ 


0.010 
- 
-:!:.002 


TYP 


40-Pln Plastic Package 


40 


o 
M 
1. or )to 00 


00 0 
D~ - 
- 
- 
- 
- 
- ~ 


UMU 
~ 


~~o 000000000 0 o~ - - - - --~ 


P 


IDENTI 
IN1 J 
1 


FICATION 
2.020 MU 
- F 
0.050:!: .020 , 
1.220MU 


"' 
r 
r-0.5~~Q'--J 
0.300 
MAX 
..-. 
±.O~~ 


~OR~9t----.\ 004gJ~~~ 
g~~ 


: 0.050:t.015 BOTH ENDS 
-I1-~'~J~3 
. 
0.125 


~0.100:!:.010TYP 
TYP 
0.040+.007TYP 
MIN 


1--------------------1~Ot 
-.002 


40-Pin Protopack Package 


I 
! 
o I 
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Package 
Information 
(Continued) 


48 
25 


PIN 1 


IDENTIFICATION 


24 


0.040 
r-~~I 
f 
DO.O .. t 
:!:.010 
TYP 


I' 
~~ 
'I 
~3! M 


! 
! ! 


1---0.600~ 


REF 


0.620 


0.125 
0.050 
0.100 
11.018 
MIN 
I.- :!:.025 
' BOTH ENDS 
-J L :!:.010 TYP 
j L :!:.003 TYP 


0.062 
RADIUS 


0.060 
0.020 


48-Pln Ceramic' Package 


48 
25 


~ 
___________________________ ~~~ ___________________________ 
24~11 


15° ~o:SoO-----j 
0.155 
' 
, 


0.01810.015 RA~P~~.Elk 
= ~ :rrC'::::r---------:,----------------------'-----------------------. 


~ 
0.015~ REF ~: 


I. 
0.650 0.00, . I o.tkE - 
0 .... ·. 
0.100 
Ilf 0.060 
r----0.610~ 
MIN. 
0.060 
TYP. 
~0.040 


48-Pin Plastic Package 


NOTE: Package dimensions are given In Inches. To convert to millimeters, multiply by 25.4. 


774 


Package 
Information 
(Continued) 


-~~ITP 
~ 
1-.750 REF-I 


0.009 
0.015 
!--0.790:t:.010-! 


33 


0.050R '~~I;:::==============~I 


.760 
I'" 
I 


LL..L..-.- 
'9 -=-==-=-=~-=-=-=-==~~~~ 
T1 
.~ 


PIN 1 


IDENTIFICATION 


32 


-rt-~II-=' :::::::::::::=2'42=5M=AX:::~~~~~::;:~~'I~ 


.185 MAX ~ 
.095 MAX 


t 
t· 
060 
It- 
.125r'N 
])20 


-:~~g 
BOTH ENDS 


.062R 


64 


64-Pin Ceramic Packago 


1----------1.437----------+1 


.1968 DIA X .003 DEEP 
TOP EJECT PINS 


.236 DIA X .003 DEEP 
BOTTOM EJECT PINS 


33 


1-------------2.170-------------J 


64-Pin Plastic Package 
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Package 
Information 
(Continued) 


776 


t- 
~::~: !~: -:1 ~I- 0.013 
0.399 SQ. 
MAX. 


1_ O.~~:Q. -I 
1-~~~ 
O 


~ 11~19 


~ 
'.09' MAX. 


METALIZATION~ I 
~.02{ I~ 1 28 ~ 
ONE CORNER ONLY 
x 45" 


~~~~ - 
- 
0.025 TYP. 


28-Pin Leadless Package 


_0.662 SQ._ 
0.640 SQ. 


lo.s~SQ_1 
0.492 SQ. 
1_ 0.475 SQ. --I 
0.469 SQ. 


-II 
ij' 
FD= 


18 


23 


28 


JL 


__ 0.025 


TYP 
I ~ 


0.040 x 45" 
TYP.3 REF. 


- 
_ 
0.058 
0.042 


44-Pin Leadless Package 


NOTE: Package dimensions are given In Inches. To convert to millimeters. multiply by 25.4. 


Package 
Information 
(Continued) 


.750 :t .011 
SO -------1 ... 1 
(19.05 :t 0.28) 
. 


~(1~~~Sa. 
I r-(1!,:~ SQ·----·~I 


I 
I 
.050 TYP 
'-(1.27) 
• 


~ I.- .020 x 45° 
II 
(0.51). 
--'1 r- (;~~) 45° TYP. 3 


-eE---r-- ;~~ TYP. 


.075 :t .008 
(1.91 :t 0.2) 


.015 
(0.38) 


I 
.060 
r--(1.27) 


-~- .050 
___ (1.27) TYP. REF. 


J 


52-Pin Leadless Ceramic Package 
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/ 


Package 
Information 
(Continued) 


778 


.960 
(24.38) 


18 


~ 


__________ .960 ________ __..1 
.. 
(24.38) 
~ 


JEDEC Type A Package 


.800 
(20.32) 


I .... ---------(~O~~~) SQ.-------_~I 


GUIDE BOSS 
3 PLCS 


1-' 


-'-SOCKET 


ORIENTATION PIN 


Textool Carrier Socket 


S8-Pin Leadless Ceramic Package 


¢ FRONT 


NOTE: Package dimensions are given in inches. To convert to millimeters, multiply by 25.4. 


~ 


.094 
. (2.39) 


.088 
(1.88) 


I 
.130 
1(3.30) 


Package 
Information 
(Continued) 


STOP 


M1 


AD1S 


AD14 


+5V 
Z8002 


NC 
Z8004 


Vi 
CPU 


NVI 


NMI 


RESET 


Mo 


= Z8004 Version 


NC = No connection 


Z8002/4 Leadless Package 


CHAMFERED 
CORNER 


= Z8003 only 


NC = No connection 


Z8001/3 Loadless Package 


ADs 


AD3 


AD2 


AD1 


GND 


ClK 


AS 


RESERVED/ABORT" 
BNi 
Nis 


RiW 


SN4 


ADs 


AD3 


AD2 


AD1 


SN2 


GND 
elK 


AS 


RESERVED AlWRT" 
BiW 


N/S 


RiW 
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Package 
Information 
(Continued) 


780 


BUSACK 


BRSTA. 


SIP/BRST/ABORT 


RiW 


GND 


Cs/AS 
os 
BUw 
Bwi[ 


STo 


ST1 


ST2 


·ST3 


BSY 
+5V 


AD14 


AD13 


Z80~O APU 


ze070 APU LecuHe~. Package 


NC .. No connection 


ze400 zeo CPU Leadless Package 


As 


A4 


A3 


A2 


A1 


Ao 


GND 


RFSH 


M1 


RESET 


BUSREQ 


AD27 (SNv 


AD28 (SN3) 
+5V 


AD29 (SN4) 


AD30 (SNs) 


AD31 (SNs) 


N/S 


101 


RESERVED 


1D0 


INT 


lEI 


GND 


lEO 


RESET 


OPT1 


OPTo 


Package 
CHAMFERED 


Information 
CORNER 
'O~ 
~ 
~~ () () () () ~ () () '9" ~ 
(Continued) 


oS' 
,;> 
; 
0 
r 
6' 


lEI 
B/A 


lEO 
CID 


M1 
AD 


+5V 
GND 


W/RDYA 
Z8444 
W/RDYB 


SYNCA 
SIO 
SYNCB 


RxDA 
RxDB 


RxCA 
RxCB 


TxCA 
TxCB 


TxDA 
TxDB 


()~~~~ ~~~~~()~ 
~~~ ~1- 
%()~Il'~~~~ 
• 
NC = No connection 
LV 
ft 
W 
W 


Z8444 SIO Leadless Package 
G 
Ei 
Q 


~~ 
&: 
CHAMFERED 
'\ 


0 


CORNER 
e 
~ 
-10 
~ <'Il" ~ 
~~~l,1-1-~~\<'o 
-... 
0 
Ao 
00 
tt 


ClK 
0, 


WR 
02 


AD 
03 


IORQ 
04 
Z8410 
NC 
DMA 
GND 


+5V 
05 


MREQ 
Os 


BAO 
07 


BAI 
M1 


BUSREQ 
NC 


~~~~~~1 
~oS' r 
v ., ; 
0 


~.1' 


~ ~()~ -10 


NC = No connection 


Z8410 DMA Leadless Package 
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CHAMFERED 
CORNER 


NC = No connection 


Z8038 
Z·F10 


Z8038 Z·FIO Leadless Packago 


Z8010 
ZMMU 


NC = No connection 


Z8010 Z·MMU Leadless Package 


lID 
[fJ 


[ID 
(ffi 


OJ 
QJ 


Do 


01 


02 


03 


04 


NC 


ST2 


ST3 


ADa 


ADs 


AD10 


AD11 


ClK 


GND 


AD12 


AD13 


AD14 


AD15 


Paclcago 
Information 
(Continued) 


CHAMFERED 
CORNER 


~ 
10<?~1-,,~~<3 ~~~10 


GND 


NC 


RD 


ZC/TOo 


NC 


ZC/TOI 
Z0430 


CTC 


ZC/T02 


IORC 


NC 


lEO 


NC 


NC = No connection 


Z8430 eTC Lcadlcss Packago 


lEO 


lEI 


INTACK 


+5V 


W/RECA 


SYNCA 


RTxCA 


RxDA 


TRxCA 


TxDA 


NC 


= Z8530 Version 
NC = No connection 


ZOO30L 
Z·SCCISCC 


NC 


NC 


+5V 


NC 


CLK/TRGo 


NC 


CLK/TRGI 


CLKITRG2 


CLKITRG3 


NC 


CSI 


R/W AlB' 


CSo CE' 


CSID/C' 


SELECT 


GND 


W/RECB 


SYNCB 


RTxCB 


RxDB 


TRxCB 


TxDB 


Both Z8030 and Z8530 are Implemantsd In a 81ngle leadle .. package and 
controlled by select pin 36 requiring: 5 volta lor Z8030; GND lor Z8530. 


Z8030L z·see/see Loadloss Packago 


----~------------------------------------------------------------------------------------ 
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R/W WR* 


SELECT 


GND 


PBo 


PBl 


PB2 


PB3 


PB4 


PBs 


PBs 


PB7 


= Z8538 Version 


NC = No connection 


ZOO36L 
Z·CIOICIO 


CSl Al· 


AS Ao· 


PAo 


PAl 


PA2 


PA3 


PA4 


PAs 


PAs 


PA7 


NC 


Both Z8036 and Z8536 are Implemented In 8 single leadless package and 
controlled by select pin 8 requiring: 5 volts for Z8036; GND for Z8536. 


Z8036L Z-CIO/CIO Leadless Package 


B/A 
RD 


A7 
B7 


Ae 
Be 


As 
Bs 


A4 
Z0420 
B4 


NC 
PIO 
B3 


GND 
B2 


A3 
Bl 


A2 
Bo 


Al 
+5V 


Ao 
ClK 


NC = No connection 


Z8420 PIO Leadless Package 
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Zilog 


Pioneering the 
Micro world 


Zilog's development system 
products feature ideal en- 
vironments for software develop- 
ment for the Z8 and Z8000 
microprocessors. The modular- 
ized design approach of the Zilog 
development systems allows the 
user a choice of hardware and 
software modules to meet current 
needs, while providing the 
necessary upgrade possibilities 
for future requirements. 
The System 8000 concept par- 
titions software and hardware 
development tools into specially 
tailored devices. Software and 
hardware checkout are handled 
by separate yet compatible prod- 
ucts. Software can be developed 
on both Zilog and non-Zilog hosts 
using available compilers and- 
cross-compilers. In either case, 
compatible hardware emulation 
systems are available at several 
levels of complexity. Standard 
RS-232 links provide for uploading 
and downloading of programs 
between hosts and emulators. 
System 8000, a high- 
performance, multiuser, multi- 
tasking software development 
host combines the commercial 
system's function and the 
development system concept. 
The 6 MHz Z8000-based System 
8000 hardware incorporates a 
high-performance Winchester 
disk, as well as intelligent disk 
and tape controllers, to further 


'UNIX is a trademark of Bell Lab·oratories. 


Comprehensive Development 
}Environments for- 
-All Zilog Mieroproeessors 


improve performance. ZEUS, the 
UNIX*-based operating system is 
specifically designed for software 
development and text processing. 
Numerous development tools are 
available, including the program- 
ming languages PLZ/SYS, C, 
FORTRAN 77, and Pascal; various 
libraries; and a symbolic debug- 
ger. Because ZEUS treats 
emulators as System 8000 
peripherals, System 8000 can 
combine with EMS 8000, Z-SCAN 
8000, Z-SCAN 8, or non-Zilog 
emulators to provide total product 
development support for multiple 
microprocessors. 


Zilog has a stand-alone, low- 
level emulation device called 
Z-SCAN, and a high-level emula- 
tion device called EMS 8000. The 
basic idea behind Zilog develop- 
ment systems· is to allow hard- 
ware and software to be 
developed simultaneously from 
the beginning of the project. 
Along with Zilog's System 8000 
host (or other UNIX hosts, such - 
as VAX or PDP 11), a multiuser 
development environment can be 
created in conjunction with the 
Z-SCAN family and the EMS 8000. 


The Z-SCAN family includes 


Z-SCAN 8000 and Z-SCAN 8, with 
future plans for Z·SCAN UPC and 
Z-SCAN 800. Z-SCAN (Zilog 
Stand-Alone Circuit Analyser) is 
designed to be easy to master 


and so low~cost that every 
engineer can afford one. 
The first in the family of the 


Z-SCANs is Z-SCAN 8000 .. which 
provides in-circuit emulation for 
both Z8001 and Z8002. It in- 
cludes user-friendly, screen- 
oriented software and one com- 
plex breakpoint. Z-SCAN 8 has 
the same features as the Z-SCAN 
8000; it also includes two hard- 
ware breakpoints and a real-time 
trace. Future Z-SCANs will pro- 
vide additional features while still 
maintaining the Z-SCAN's user- 
friendly interface and low cost. 
EMS 8000 is a sophisticated 
emulation management system 
that aids in the development of 
Z8000 implementations. By pro- 
viding logic state analysiS, high- 
speed emulations (up to 6 MHz), 
complex triggering, a large real- 
time trace buffer, and large map- 
pable memory, EMS 8000 makes 
emulation and debugging both 
easier and faster. EMS 8000 also 
provides in-circuit emulation for 
Z8001, Z8002, and Z8003. 


The Z8 and Z8000 Develop- 
ment Modules are single-board 
microcomputers that permit the 
development of code for the Z8, 
Z8001, or Z8002. They facilitate 
prototyping with large wire-wrap 
areas and are totally transparent 
to the CRTs and host CPU 
systems: 
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Zilog 


Features 


Overview 


Functional 
Description 


c Upgrades an MCZTM or PDS system to a 
16-bit system with 256K byt~s of memory. 


[J Provides complete Z8000-based software 
development tools that execute at 6MHz: 
screen editor, translator, compiler/ 
assembler, debugger. 


[J All software supplied in source code 
form to allow customization for 
applications. 


[J EXisting Z80 programs continue 
to run. 


The Z8000 Dual-Processor System Upgrade 


Package provides 16-bit processing power, 
256K bytes of random access memory, and 
software development tools for Zilog's 
Z80-based MCZ and PDS systems. The package 
consists of a Z8000 Microprocessor Board 
(MPB/256), a screen editor, Z80 to Z8000 
translator, and a Z8000 assembler and 
debugger. 


Hardware. The Z8000 MPB contains a 6MHz 
Z8001 CPU and 256K bytes of RAM. The board 
uses a FIFO for inter-CPU block transfers. The 
FIFO is implemented using control logic and a 
lKx8 static RAM chip and can be accessed 
sequentially by either the Z80 or the Z8000. 
Software resolves any contention for 
ownership. 
The MPB can be plugged directly into the 
top slot of an MCZ-1I05 with no modification to 
the system. Or, it can be used in any vacant 
slot of an MCZ-1I20 or PDS 8000 system, and 
may require minor modification to the 
backplane. 


~~([J)([D@TM IID'i1ilalll:1~~@(Cess@ll 
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The Z8000 MPB plugs directly into the 
backplane of the Z80 system and works with 
the Z80 and RIO. When the Z8000 is running, 
the Z80 acts as a peripheral processor that 
manages the resources of the host system. 
When the Z8000 is not activated, the system is 
controlled by the Z80 and there is no func- 
tional change due to the additional 
Z8000 MPB. 


Software. The software tools provided with the 
Z8000 Dual-Processor System Upgrade 
Package include a screen editor, Y (a multi- 
level language compiler), a symbolic debug- 
ger, a Z80 to Z8000 translator, and the 
interface software between the Z80 and Z8000. 


The screen editor takes advantage of the 
6MHz Z8000 and 256K RAM to provide an 
easy-to-use, efficient means of entering and 
modifying programs. The screen provides a 
"window" over the current copy of the file in 
memory. The cursor may be moved anywhere 
in the window to indicate the position where 
characters are to be added, deleted or 
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Functional 
Description 
(Continued) 


790 


replaced. In addition, commands are available 
to find and change strings of text and to 
delete, move or copy blocks of text. The 
screen editor is designed to be used with an 
Infoton 200 or a Visual 200 terminal. It can, 
however, be modified to work with almost 
any CRT. 
The compiler, Y, is a multi-level language. 
It includes Z8000 assembly language with Zilog 
mnemonics, Pascal-like control structures, data 
types, arithmetic expressions with automatic or 
specified allocation of registers, procedure 
calls with parameter passing, and a descriptive 
compiler language. The different levels may, 
for the most part, be freely mixed. The Y com- 
piler features direct, one-pass code generation 


into memory, immed'iate execution of 
statements, conditional compilation, user- 
defined language extensions and symbolic 
debugging. 
The debugger can operate in two modes: 
Debug and Command. With the symbolic 
debugger in Debug mode, any instruction 
typed is executed immediately, with registers 
preserved from one line to the next. In addi- 
tion, there is a special set of debug commands. 
The set includes commands to display and 
change memory and/or registers, set and 
remove breakpoints (up to eight), locate 
strings in memory, display stack history and 
execute a specific number of instructions. 


Zilog 


FEATURES 


fill Snapshot feature permits partitioning of a large real- 


time trace module into many small trace memories. 


CJ Up to 126K bytes of high-speed,static, mappable 


memory can be accessed by the target system. 


mPulse output feature permits use of a high-end logic 
analyzer. 


g Network debugging is supported. 


[] Full access to the target microprocessor's registers, 
memory, and I/O space is permitted. 


[] Transparent mode allows the same terminal to be 
used for host and EMS user interface . 


• Emulates Z8001/3 or Z8002 CPUs at 6 MHz clock 


rates. 
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N a: .. 
[] Complex triggering. 
00 


[l Large real-time trace buffer. 
§ 


[] Large mappable memory space. 


[J Real-time partitionable trace module for multiple re- 


cordings of program execution. 


[J Three parallel event comparators which can be 


allocated for trigger, trace, breakpoint recognition, 
and enable/disable functions. 


[J General-Purpose counter for benchmarking critical 


software routines. 


Figu~e 1. Emulator System 8000 (EMS) 
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GENERAL DESCRIPTION 


The Emu'lator System 8000 (EMS), shown in self-test con- 
figuration in Figure 1, is a state-of-the-art in-circuit sub- 
system. The EMS supports the software/hardware 
engineer in developing products using the Zilog Z8000 
family of microprocessors and peripheral components. 
Combined with Zilog's enhanced UNIX* System (ZEUS), 
EMS 8000 provides the designer with a complete and 
powerful set of tools for speeding up the product 
development cycle. 


The EMS links the application software developed on a 
host system and the target system, and aids in the in- 
tegration of the software into the target system by ex- 
ecuting in a real-time environment. The EMS uses the full 
capabilityof the target microprocessor and can start or 
stop program execution or perform single-step execu- 
tion. The user has full access to the target micro- 
processor's registers, memory, and I/O space. 


SCREENS 


The EMS is an interactive operating syster:n that provides 
self-prompting commands and a set of powerful tools for 
complex debugging. The EMS command entry is organ- 
ized into a set of pages called screens. Each screen is 
dedicated to a particular function and contains the com- 
mands and data fields necessary to accomplish specific 
functions. The screens are designed to fit on a standard 
display terminal, 80 columns wide by 24 lines long. 


The EMs is modular in deSign with a friendly, screen- 
oriented, self-prompting user interface. Highperfor- 
mance is gained with a 1024 entry, real-time trace that is 
qualifiable and triggerable, and can be enabled with 
multilevel event recognition. Also, newly developed pro- 
grams can be loaded into the development (target) hard- 
ware and executed in a real-time environment. The EMS 
can be networked into eight distinct Z8000 microproc- 
essors that start and stop simultaneously. 


Individual emulator systems can be defined as being 
either in or out of a break group. Systems which are out- 
side of a break group can function as independent' 
emulators with all of the EMS 8000 capabilities and full 
use of host resources. Systems which are in the break 
group are used to debug multiple processor systems. 


The user communicates with EMS through five com- 
mand (menu-driven) screens and two support screens. 
The command screens are entered by typing the first let- 
ter of the screen name (e.g., A for allocation). Screens 
can be changed by sequentially typing <TAB> and the 
first letter of the scre~n name. Table 1 explains the 
screens and their functions. 


Table 1. EMS Screen Descriptions 


Screen 


Allocation 


Configuration 


Pattern 


Mapping 


Debug 


Help 


Change 


Function 


Command (Menu·Driven) Screens 


Assigns EMS resources to specific tasks such as tracing and breakpOints. 


Allows various hardware controls to configure global features of EMS. 


Allows entry of recognized patterns. 


Substitutes EMS mappable memory for target memory. 


, Examines and edits memory/registers, I/O, displays trace results, begins emulation, sets 
software breakpoints, turns watch area on and off, uploads and downloads files to and 
from the host computer, single/multiple steps through program execution. 


Support Screens 


Lists global command controls and helpful reminders not listed in the above menu 
screens. It can be displayed on all other screens by typing a <?>. 


This is the intermediate step between two command screens and is entered by typing a 
<tab>. 


·UNIX is a trademark of Bell Laboratories, 
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HARDWARE DESCRIPTION 


The EMS is a full-featured emulation peripheral. The 
heart of the EMS is a Central Controller Unit (CCU) with a 
4 MHz Z80, 256K of dynamic memory, and 16K of ROM. 
The CCU contains the monitor program that provides a 
screen-oriented user interface, and operates con- 
tinuously to allow the user to monitor the progress of 
emulation and breakpoints in real-time. The other EMS 
modules include a two-board Trigger module, a real-time. 
Trace module, an External Probe interface module, a 
Mappable Memory module, and a microprocessor Per- 
sonality module with a CPU Pod (Figure 2). 


Figure 3 shows a fully configured EMS syster:n with the 
following units: 


II EMS 8000 


B CPU Pod/cable assembly. The CPU Pod contains the 
processor chip to be emulated plus the required inter- 
face circuitry. Pods are available for the Z8001 /3 and 
Z8002. 


EI ·64K mappable memory (standard). 
62K mappable memory addition (optional). 


c Host computer and user CRT terminal (required). 


GI External probes (optional). 


[] Target (the system being emulated). 


TO 
TERMINAL 


TO HOST 


COMPUTER 


TO BREAK 
GROUP EMS's 


CENTRAL CONTROLLER 


) 


SERIAL u." 


COMMUNICATIONS 
CHANNELS 


INTERRUPT 


DATA/ADDRESS READ·WRITE CONTROL 


TRIGGER MODULE 


RESOURCE A 
RESOURCE B 
RESOURCE C 


GENERAL PURPOSE 


COUNTER 


TRACE BOARD 64X1 K 


TIMING STROBES 
SYNCHRONIZED TO EMULATED 


The EMS uses dual-processor architecture to unburden 
the emulating processor from the configuration chores 
of the emulation system. (The Z80 CPU is used for EMS 
configuration and monitor functions and the Z8000 CPU 
for actual emulation.) This independence allows for im- 
proved debugging when unreliable target operation 
occurs. 


A 10 MHz Z8000 CPU is used to emulate the 6 MHz 
maximum clock rate of the EMS to compensate for tim- 
ing delays caused by buffering. The buffering p.rovides 
better emulation control in problem targets and allows 
mappable m~mory to override existing target memory. 
Fast (90 ns) mapped memory allows emulation at 6 MHz 
with no Wait states. (Wait states can be forced if desired 
for compatibility with target memory.) Multilevel pattern 
recognition resources can be allocated in complex se- 
quential, logical, and enable/disable combinations to the 
functions of trace qualifying and triggering, event coun- 
ting, and timer modes. The counter/timer modes support 
a long count of 48 bits (40 when time is displayed in 
microseconds). This ensures adequate count capability 
for analysis of human-related events in real time. 


TARGET SYSTEM 
GENERATES CLOCK 
(EMULATED PROCESSOR ENVIRONMENT) 


EMULATOR BOARD 
MAPPABLE 


MEMORY BOARDS 


63 BLOCKS OF 


2K BYTES 


Figure 2. EMS 8000 System Block Diagram 
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SOFTWARE DESCRIPTION 


The EMS can use ZEUS when the System 8000 is the 
host computer. This total system provides a complex 
hierarchical file structure that includes C, PLZ/SYS, a 
Z8000 assembler, a compiler writing system, and a 
general-purpose microprocessor. Because the EMS in- 
terfaces with Zilog computer systems, the user has ac- 
cess to powerful development tools for speeding up the 
product development cycle. Software downloads to 
either the ZEUS (UNIX) or RIO operating systems. 


EMS software is friendly and easy to use. The menu 
prompt for each EMS screen reminds the user about the 
type of data that is available or the options that are per- 
mitted. Error checking prevents the user from entering il- 
legal states and allows graceful recovery from emulation 
target problems (e.g., bad clock or power failure). Global 
command keys allow the user to control the starting and 
stopping of emulation, execution of command scripts, 
and entering Transparent mode independently of the 
command screens. A Help screen, which summarizes 
global commands and command entry, is available to 
help the user gain familiarity with EMS. 


TERMINAL 


(ADM 31, CITOH, 
Tel evideo 920, VT 100, 
VTZ 2/10) 


The EMS operating system is downloaded from a host 
computer, allowing easy implementation of future up- 
grades to improve its effectiveness and applicability. The 
hosts that can be configured with the EMS are: 


[J Zilog System 8000 


[] Vax UNIX 


EJ PDP 11 UNIX 


[] Zilog MCZ 1, MCZ 2, and ZDS 1/40 


The terminals that can be configured with EMS 8000 are: 


I:l ADM 31 


IJ CITOH 


[] Televideo 920 


[] VT 100 


IJ VTZ 2/10 


HOST 
(MCZ·1, MCZ·2, PDP 11, 


UNIX, Vax UNIX, ZDS 
1140, Zilog System 8000) 


EMS 8000 


794 


LOGIC ANALYZER D 
o 
o 


CPU POD 


'--r 


EXTERNAL PROBE 


TARGET SYSTEM 


Figure 3. EMS 8000 System Configuration 
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Cl ZBOOI/Z8002 CPU Evaluation and 
Debug Support 


[;! 16K Words Dynamic RAM 
(Expandable to 32K for User Code 
Execution and Debug 


, 0 32 Programmable I/O Lines 


Cl EPROM Monitor and Debugger 
o Transparent Operation Allows 
Software Development without 
Disconnection from CRT and Host 
System 


D RS-232C St~ndard Serial Interfaces 
Compatible with Most CRT Ter- 
minals and Development Hosts 
o Wire-wrap Area for Prototyping 
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OVERVIEW 


The 28000 Development Module is a 
complete, single-board microcomputer 
that is used as a tool for the evaluation 
and debug of 28000-based micro- 
processor systems. The Development 
Module is used in the first stages of the 
design and development process, not 
only as a tool for evaluating 28000 
microprocessor capabilities, but also as 
an environment in which code can be 
executed and debugged. 


Evaluation. The Development Module 
provides a ready-made environment in 
which the user can execute software 
unique to his 28000-based application, 


evaluate the CPU's performance, and 
then reach a realistic decision about its 
suitability for a specific application. 


Software Debug. In addition to use as 
an evaluation,tool, the 28000 Develop- 
ment Module can be used to debug 
and modify user code. For the software 
designer, the Development Module is a 
real 28000 environment in which he 
can execute code and qarry out fairly 
extensive debugging. For the hardware 
designer; the Development Module is 
an example of 28000 hardware design 
which provides special hooks and wire- 
wrap facilities to strap on additional 
logic. 
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FUNCTIONAL DESCRIPTION 


Z8000 code developed on a software 
host may be downloaded serially to the 
Development Module RAM area via a 
serial port, and executed and debugg- 
ed under EPROM monitor control. 
Once the system is connected, no fur- 
ther disconnection is necessary as the 
module has two serial ports (one con- 
nected to a host and the other con- 
nected to a CRT terminal). A simple 
software command makes the develop- 
ment process transparent in the serial 
path, thereby allowing direct communi- 
cation between the host and terminal. 
The serial RS-232C interfaces allow vir- 
tually any software development host 
and CRT terminal to be used . .For 
PROM-based code testing, the devel- 
opment module is self-contained and 
can operate stand-alone with a CRT 
terminal, since the host is only 
required for storage of user code 
on disk. 
A variety of jumper areas and 
switches permit the selection of clock 
rates ranging from 2.5 to 3.9 MHz; the 
use of 2708, 2716, or 2732 EPROMs; 
the use of 4K or 16K RAMS; serial 
interface to modem, terminal, or tele- 
type; VO port addressing; and baud- 
rate selection from 110 to 19200 baud. 


Hardware. The 28000 Development 
Module is available in two versions: 
one supports the segmented 28001 
microprocessor; the other supports the 
non-segmented Z8002 microprocessor. 


Z8001 Development Module. The 
Z8001 Development Module consists of 
a Z8001 CPU, 16K words of dynamic 
RAM (expandable to 32K words), 4K 
words of EPROM monitor (user- 
expandable to 8K words), a 280A SIO 
providing dual serial ports, a 280A 
CTC peripheral chip providing four 
counter/timer channels, two Z80A PIO 
devices providing 32 programmable 
VO lines, and wire-wrap area for pro- 
totyping hardware. 


za002 Development Module. The 
28002 Development Module consists of 
a 28002 CPU, 16K words of dynamic 
RAM (expandable to 24K words), 2K 
words of EPROM monitor (user- 
expandable to 8K words), a Z80A SIO 
device providing dual serial ports, a 
Z80A CTC peripheral device providing 
four counter/timer channels, two 280A 
PIO devices providing 32 program- 
mable I/O lines, and wire-wrap area 
for prototyping. 
' 
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COMMAND 
INTERPRETER 


DEBUGGER 
TERMINAL 
HANDLER 


UPLOADI 
DOWNLOAD 


Figure 1. Monitor Block Diagram 


Software. The monitor software 
(Figure 1) contained in EPROM (4K 
words for the 28001 and 2K words for 
the 28002) provides debugging com- 
mands, VO control and host interface. 
It consIsts of a terminal handler, com- 
mand interpreter, debugger and 
upload! download handler. 


Terminal Handler. A Terminal Handler 
provides interface to the console 
device to facilitate output to a display 
or printing mechanism and input from 
a standard ASCII keyboard. 


Debugger. The Debugger provides a 
basic set of debug commands to allow 
the user to start and stop program exe- 
cution, display and alter CPU 
registers, flags or memory, and trap 
instruction sequences. 


Command Interpreter. The Command 
Interpreter scans console inputs, 


/ 


ADDRESS 
BYTE CHECK 
COUNT 
SUM 


ensures command validity and passes 
to other software modules in the 
monitor. 
Upload/Download Handler. The 
UploadIDownload Handler provides an 
interface between the serial connection 
and the host computer, the command 
interpreter and the memory resources 
of the 28002 Development Module. It 
formats and interprets asynchronous 
data streams to and from the host and 
provides error checking and recovery 
for the serial interface (see Figure 2). 


Memory Organization. Tables 1 and 2 
show the memory maps for tIte two ver- 
sions of the Development Module. The 
organization of ROM and RAM in.both 
the segmented and nonsegmented 
modes is indicated. 


, 


DATA 
CHECK C 


SUM 
R 


I I I 
I 
I 
I I I I 
I I I I 
I 


Figure 2. Serial Data Format 


1047-001,002 


Segment 0 
Segment 1 


Address (Hex) 
Memory 
Address (Hex) 
Memory 
Address (Hex) 
Memory 


0000 
Monitor 


OFFF 
EPROM 
1000 
User EPROM 


3FFF 
(User Installed) 


4000 
Standard 
BFFF 
RAM 


COOO 
Expansion RAM 
FFFF 
(User Installed) 


Table 1. ZaDD2 Development Module Memory Map 


MONITOR COMMAND SUMMARY 


The folloWing notation is used in the 
command description: 


< > Enclose descriptive names for the 
quantities to be entered, and are 
not actually entered as part of the 
command. 


[] 
Denote optional entries in the com- 
mand syntax. 


Denotes "OR", ego WIB denotes that 
either W or B may be used but not 
simultaneously. 


< 
Prompt sign for the nonsegmented 
28002 monitor. 


Prompt sign for the segmented 
28001 monitor. 


The following commands apply when 
the 28001 monitor is used. All com- 
mands listed remain the same except 
those that pe~it reference to seg- 
mented addresses as follows: 


<address> = 
[ < segment number>] < offset 
address> 
< segment number> = 


"<" < hex number in 
7-bit range>">" 


0000 
IFFF 
2000 
3FFFF 
4000 
49FF 


4AOO 
BFFF 


COOO 
FFFF 


BREAK < address> 
[<n>] 
Sets and clears a breakpoint at a 
given memory address. The option 
< n > allows specification of the 
number of occurrences, where n is 
from 1 to 128. The default is one. 


COMPARE 
<address 1 > 
<address 2> <n> 


DISPLAY < address> 
<n>[LIWIB] 


FILL < address 1 > 
< address 2> < word> 


Compares two blocks of memory 
data beginning with the addresses 
speCified for < n > bytes, where n 
is from 1 to 128. Errors are 
reported on the console device. 


Displays and modifies memory for 
< n > number of words or bytes. 
The optionaf entry allows data to 
be handled as bytes, words, or 
long words. The default is words. 


Stores the < word> from memory 
address i to and including 
address 2. 


Monitor 
EPROM 


User EPROM 
(User Installed) 


Monitor RAM 
(Scratchpad Area) 


Standard RAM 


Expansion RAM 
(User Installed) 


0000 
3FFF 
4000 
FFFF 


Expansion RAM 
(User Installed) 


Unused 


Table 2. ZaDDl Development Module Memory Map 


GO 
Begins program execution at the 
address contained in the current 
PC; execution is resumed where it 
was last interrupted. All registers 
are restored prior to execution. 


IOPORT < address> 
Allows direct communications from 


[WIB] 
the console to a select~d I/O port. 
A word (W) or a byte (B) may be 
read from the selected port and a 
word or byte. may be sent to the 
selected port; default is byte. 


JUMP < address> 
Unconditional branch to the speci- 
fied address. All registers are 
restored prior to execution. 


MOVE < address 1 > 
Moves contents of a memory block 
<address 2> <n> 
from source address < address 1 > 
to destination address 
<address 2> for <n> bytes. 


NEXT[<n>] 
Executes the next < n > machine 
instructions. <n> may be from 
1 to 128. ILn is omitted, 1 is 
assumed. 


PUNCH < address 1 > 
Punches a copy of memory from 
<address 2> 
address 1 to address 2 on paper 
tape on the console device. Auto- 
matically turns on punch and a 
null leader is created. 
Upload/Download section 
describes the tape format used. 


QUIT 
Places serial channels into trans- 
parent mode. The 28000 Develop- 
ment Module must be connected to 
both the 2ilog host and the console 
device, and the Development 
Module acts as a message 
switcher. 


REGISTER 
Allows examination and modifica- 
[ < register name> ] 
tion of 28000 registers. 8-bit, 16-bit 
or 32-bit quantities may be 
selected by the appropriate 
register-naming conventions. 


TAPE 
Loads memory from paper tape via 
the console device. The 
Upload/Download section 
describes the tape format used. 
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SPECIFICATIONS 


Microprocessor 


ZSOOI or ZS002 CPU 
Clock Rate: 2.5 MHZ or 3.9 MHz 


Memory 


ROM: 2K or 4K Words (Expandable 
to 8K Words) 
RAM: 16K Words (Expandable 
to 32K Words) 


ORDERIN~ INFORMATION. 


D&scription 


Input/Output 


Parallel: 32 Lines (Two Z80A-PIOs) 
Serial: Dua! RS-232C or RS-232C and 
Current Loop (ZSOA-SIO) 


Note 
The user has access to all bus signals to allow 
custom system expansion into the wire-wrap area 
off·board. 
Interrupts 
Maskable Vectored (256) / Maskable 
Non-vectored, Non-maskable, 
Segmentation Trap 


Part No. 


05-6168-01 
05-6101-01 
05-6171-01 


28001 Development Module 
28002 Development Module 
28001 Conversion Kit (converts 28002 Development Module into 


28001 Development Module) 


Systems recommended for use with the above: 


Description 


2DS-l Series Development Systems 


PDS 8000 Series Development 
Systems 


System 8000 Family 
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Prerequisi te 


28000 Software Development Package 


28000 Software Development Package 


28000 Software Development Package 


Power 
+5 V/ 3 A 
+12 V/ 1 A 
-12 V/ 0.2 A 


Physical 
Height 


Width 
Depth 
Weight 


1.75 in. (4.5 em) Inclusive of 
Standoffs 
14.0 in. (35.6 em) 
11.0 in. (27.9 em) 
Approx. 30 oz. (850 gm) 


OQ·1047'()2 


Zilog 


II Two 4K zas are used on the board:' 
one as board manager and one fdr 
emulation (without real-time trace) 
or other user-defined configuration. 


EI 4096 bytes of static RAM allow con- 
venient creation and debugging of 
user code . 


.. On-board socket tests user code in a 
2716 or 2732 EPROM. 


II Up to 4096 hardware breakpoints on 
address compare cover the entire 
internal ROM space. 


13 Versatile monitor software allows 
debugging, with- register/mET,mory 
examination and manipulation, and 
file upload and download. I 


II ·"Transparent" operation allows 
terminal-to-host communication 
without disconnecting the'Develop- 
ment Module . 


• Wire-wrap area for prototyping . 


• za board management is operated at 
7.3728 MHz for baud rate purposes. 
The User za has switch-selectable 8 
or liMHz crystals. 


OVERVIEW 


The za Development Module is a 
Single-board microcomputer system 
specifically designed to assist in the 
development and evaluation of hard- 
ware and software designs based on the 
28 microcomputer family. It allows the 
user to build a prototype using the ~ 
prototyping deVice, thereby developing 
code that will eventually be mask- 
programmed into the 28 on-chip ROM. 


Two 28 devices exist on the za 


Development Module: the Monitor za 
serves as a board controller, while the 
User 28 is user-definable. All user 
ports on the User za are uncommitted 
and can be configured to suit any ap- 
plication. 


18$ Developmemlft 
Mo«B MXS 


Product 
Description 
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Up to 4096 bytes of high-speed static 
RAM are available to simulate internal 
ROM. Also, an on-board EPROM 
socket allows the user to substitute 
EPROM for the ROM. This enables the 
user to store the software without 
building special hardware. 
The EPROM-resident monitor soft- 
ware offers register and memory 
manipulation, as well as a convenient 
means to upload and download soft- 
ware between the host and user RAM 
space. ' 


The Development Module connects 
to the CRT terminal and host system 
via two on-board RS-232-C serial ports; 
this places the Development Module 


between the CRT and host. A simple 
command makes the Development 
Module transparent in the serial path, 
which allows software to be developed 
on the host-resident assembler without 
disconnecting the Development Module 
from the CRT and host. 
. The Development Module can 
operate stand-alone for simple debug- 
ging operations, or it can interface 
directly to a host system such as the 
2ilog System 8000 for software develop- 
ment and file storage. 
Fourteen square inches of wire-wrap 
area with 5 V and ground points are 
provided near the User 28 for proto- 
typing. 
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FUNCTIONAL DESCRIPTION 


Hardware. The two Z8 microcomputer 
units (Monitor MCU and User MCU) 
are at the heart of the Z8 Development 
Module. The Monitor MCU controls 
operation of the User MCU using the 
monitor/debug software, which resides 
in 4K bytes of EPROM. Hardware 
breakpoint logic provides a maximum 
of 4096 breakpoints. Single-stepping 
with software trace capabilities is also 
available. 


nal pins. This effectively leaves all 
ports on the User MCU unconfigured 
and available for the user. The 4K 
bytes of static RAM on the inte~nal bus 
are reserved for code that is executed 
by the User MCU. Execution is done in 
real time at full processor speed. 


reinitialize the system, respectively. 
-The baud rate, from 110 to 19200, is 
the same baud rate used for the ter- 
minal and host and is selected with an 
on-board, four-element DIP switch. 


Software. The monitor/debug program 
includes debug, disassembly, input! 
output, control, and host interface Cjom- 
mands. These commands are grouped 


The User MCU is controlled by the 
Monitor MCU via internal address/data 
and control lines brought out to exter- 


In addition to the wire-wrap area, a 


40-pin header (3M type 2395-1002) for 
the User Z8 can connect to a ribbon 
cable with a 40-pin plug, which will 
then plug into a target system. Two 
switches, Mode and Reset, provide a 
means to re-enter the Monitor and to 


into four major functional blocks: 
' 


monitor, debug, manipulation, and file 
commands (see the following command 
list). 
. 


Z8 Development Module 


Monitor Commands. This group of commands controls 
execution of the User MCU, monitors user interrupts and 
transfers control from the monitor to the host system. 
GO <ADDRESS> 
Causes User MCU to execute its 
program and disallows further 
debugging until a BREAK or 
HALT command is encountered. 


HALT 


QUIT 


INTERRUPTS [E/D] 


800 


Halts program execution of the 
User MCU. 


Returns control to the host system 
and enters the "transparent" mode. 


Enables or disables all user- 
generated interrupts. Note: All 
user interrupts are automatically 
disabled when a breakpoint is 
encountered. It is necessary to 
reenable such interrupts with this 
command. 


Debug Commands. This group of commands allow~ the user 
to debug code by tracing through code and setting break- 
points and jumps to specified locations within the "internal" 
ROM space, which is simulated in 4K bytes of RAM. 


BREAK < ADDRESS> 
Sets a breakpoint at the specified . 
address. 


KILL [ < ADDRESS> ] 
Clears the breakpoint at the 
specified address. 


JUMP <ADDRESS> 
Allows the User MCU to jump to a 
specified address anywhere within 
the internal ROM space by chang- 
ing the value of the Program 


. Counter. 


NEXT [<n>] 
Causes execution of n instructions 
of the ·User MCU and then halts 
the User MCU. 


TRACE 
Causes single-step execution of the 
User MCU. Every instruction 
executed is output to the console. 


~ 
MONITOR 
TRACE 
I-CODE 
EPROM 
STOP/GO 
REGISTERS 
'\r- 
l~ 
2"':::... 


USER 
.............. ~ 
t-. 
MONITOR DATA BUS 
\ 
DATA H 
MUX r:i 
I 
I 


V 


BUS 


MONITOR 
MONITOR 
BREAK 
PROGRAM 
USER @ 
MCU 
EPROM 
POINT 
COUNTER 
RAM 
MCU 
n 
...::~ 
~ 
ir 
ir 
;L- 
t-. 


MONITOR ADDR BUS 
ADDR 
MUX "k. 
V 


BUS 
A 
~ 


( 
) 
RS232C 
PORTS 
... 
r 
JJ.JJ. 
TO CRT 
TO HOST 


Z8 Development Module Block Diagram 


Manipulation Commands. The manipulation commands 
display and alter registers and memory. This group can be 
subdivided into two categories: register manipulation and 
memory manipulation. 


Register Manipulation 


REGISTER [<l{EG 
NUMBER>] [< NEW 
REG VALUE>] 
WORKING REGISTERS 


PHILL <STARTING 
REGISTER> < NUMBER 
OF REGISTERS> 
[<DATA BYTES>] 


Memory Manipulation 


Allows examination and modifica- 
tion of the Z8 internal registers. 


Displays contents of the current 16 
working registers. 


Stores the sequence of DATA 
BYTES into User MCU registers 
beginning at the STARTING 
REGISTER and continues for the 
NUMBER OF REGISTERS 
specified. 


DISPLAY [ < STARTING Allows display and modification of 
ADDRESS> [<n> 11 
user memory contents for n 
number of bytes. 


SET <ADDRESS> 
<LENGTH> 
[<DATA BYTES>] 


FILL < STARTING 
ADDRESS> 
<LENGTH> 
[<DATA BYTES>] 


MOVE < SOURCE 
ADDRESS> 
< DESTINATION 
ADDRESS> [<n>] 
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Allows a sequence of data bytes 
beginning at the ADDRESS speci- 
fied to be written into user 
memory. 


Stores the sequence of DATA 
BYTES into user memory begin- 
ning at the starting ADDRESS and 
continues for the LENGTH 
specified. 


Moves contents of a user memory 
block from a source address to a 
destination address for a length 
of n bytes. 


COMPARE - 
<ADDRESS 1> 
<ADDRESS 2>[ <n>] 


ZAP[ < STARTING 
ADDRESS> [ < n> 11 


Compares two blocks of user 
memory data, one beginning at 
ADDRESS 1 and the other at 
ADDRESS 2 for n bytes. 


Disassembles' and displays code at 
a specified starting address for a 
specified number of bytes. 


File Commands. The file group enables the user to upload 
and download programs to and from the host system. 


LOAD 
<FILE NAME> 


UPLOAD 
<FILE NAME> 
<ADDRESS 1> 
< NUMBER OF BYTES> 
[ < ENTRY ADDRESS>] 


Downloads a file to user memory 
starting at the low address of the 
file and continuing until the entire 
file is transferred. 


Creates a RIO file image of user 
memory, beginning at ADDRESS 
I, creating default length records, 
and imaging memory for the 
specified number of bytes. 


Note: The follOWing notation is used in the command descrip- 
tion. 
< > Enclose descriptive names for the 
quantities to be entered, and are not 
actually entered as part of the 
command. 


[] 
Denote optional entries in the com- 
mand syntax. 
. 


Denotes "or." 
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SPECIFICATIONS 


Processor: 
Two 64-pin DIP zas 
Pin spacing Is 0,070 
Row spacing Is 0.75 


CPU Clock Frequency: 
7.37 MHz for Monitor 
8/12 MHz for User 


Memory: 
Monitor Z8 
Scratch Pad RAM 
RAM memory size: 1 K bytes 
RAM addressing: %2000 to %23FF 
Minimum speed: 300 ns 


EPROM 
Word size: 8 bits 
Memory size: 8K bytes' 
Addressing: 0 to %FFF Internal 
% 1000 to % IFFF external 
Minimum speed: 350 ns 


ORDERING INFORMATION 


Part No. 
05-6158-01 


05-6222-01 


Description 
Z8 Development Module 
(2K). Includes one serial 
interface ribbon cable 
and reference manual. 


Z8 Development Module 
(4K). Includes one serial 
interface ribbon cable 
and reference manual. 


Systems recommended for use with above: 


Description 
Prerequisites 


System 8000 
Z8 Assembler 
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User Z8 
RAM (EPROM equivalent) 
Word size: 8 bits 
Memory size: 4K bytes 
Addressing: 0 to %FFF (relative to 


User) 
%9000 to %9FFF (relative' 
to Monitor) 
Minimum speed: 350 ns 


Baud rate: Programmable to 110, 150, 
300, 600, 1200, 2400, 4800, 
19200 bps 
Emulator cable length: 12 inches max. 


Input/Output: 


Monitor Z8 
Baud rates: Programmable to 110, 150, 
300, 600, 1200, 2400, 4800, 
9600, 19200 bps 
Connector type: Two 25-pin DB-25S 


connectors 


User Z8 
Parallel interface: 32 110 lines undefined 
Connector type: 40-pin PC edge 
connector 


Dimensions (LxW): 
29.94 cm (11 in.) x 35.56 cm (l4Vl in.) 


Power Requirements: 
I.4Aat +5Vdc ±5% 


Environmental: 
o to 50°C (+ 32° to + 122°F) 
Up to 90% humidity without condensation 


Zilog 


FEATURES 


CJ 
Portable, stand-alone, in-circuit 
emulator (ICE) for lilog's 
Universal Peripheral Controller 
(UPC). 


[] 
Emulates six versions of the 
UPC: l8093, l8090, l8094, 
l8590, l8593 and l8594. 


OVERVIEW 


The l-SCAN UPC is a simple and 
cost-effective development tool 
that emulates four versions of 
'lilog's Universal Peripheral Con- 
troller (UPC)' As a portable in- 
circuit emulator (ICE), the l-SCAN 
U PC is an ideal tool for system 
development from design through 
manufacturing. 


i>llo8iuacl 
Brief 
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[J 
Connects to the host and ter- 
minal via standard RS-232-C 
interface. 


[] 
Emulates loBUS and non- 
loBUS UPCs with either mask- 
ed ROM or proto RAM/EPROM. 


Both loBUS compatible and non- 
loBUS compatible types of UPC 
are emulated by the l-SCAN UPC. 
The loBUS compatible l-UPCs that 
are emulated are the l8090 and 
l8094. The non-loBUS compatible 
UPCs that are emulated are the 
l8590 and the l8594. Connection 
with the host and a terminal is 


g 
Single-step trace capability. 


II Monitor software allows file 


upload and download, register 
and memory manipulation. 


accomplished via two RS-232-C in- 
terfaces. 


By supporting eight popular ter- 
minal types and a wide variety of 
hosts, the Z-SCAN UPC is easily in- 
tegrated into most operating 
environments. 
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FUNCTIONAL DESCRIPTION 


The Z-SCAN UPC is physically 
located between the host system 
and the user's terminal, connected 
via the RS-232-C interface. The 
target cable connects directly to 
the front of the Z·SCAN for safety 
and convenience. The Z-SCAN 
UPC can operate in stand~alone 
mode for simple debugging opera- 


, tions, or it can be placed in 
transparent mode to allow software 
development with the host. 


Hardware 


The Z-SCAN UPC contains both a 
Z8 MCU and a UPC. The Z8 MCU 
controls monitor functioning, in- 
cluding operational commands and 
debug software. The UPC itself 
features a 256-byte register file in- 


cluding three 1/0 port registers, 
234 general-purpose registers, and 
19 control, status, and special 110 
registers. 


Twenty-four pins can be dedicated 
to 110 functions. These pins are 
grouped logically into three eight- 
line ports, which, can be configured 
in various combinations as input or 
output, with or without handshake, 
and with push-pull or open-drain 
outputs. 


Software 


The monitorldebug program 
resides in 4096 bytes of PROM and 
contains debug, 1/0, control, and 
host interface commands. This 
software is divided into four func- 
tional groups: 


.. Monitor commands control the 


Z8 MCU to monitor interrupts 
and transfer control from the 
monitor to the host system. 


• 
Debug commands allow trac- 
ing and jumps to user-specified 
PROM locations. 


III 
Manipulation commands permit 
display and alteration of 
registers and memory. 


II File commands enable the user 
to upload and download to and 
from the host system. 


In addition, Z~SCAN UPC software 
supports eight popular terminal 
types and easily interfaces to a 
wide variety of host systems. 


Z·SCAN UPC 
.....------- IN·CIRCUIT EMULATOR 
(ICE) 


TARGET BOARD 


Figure 1. Stand·Alone Development System 
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00-2322-01 
2322-001 


Zilog 


II Provides real-time emulation 
capability for the family of Z8 
Microcomputers. 


f.'!I 
Operates with Zilog systems 
and other hosts; Z-SCAN 8 
uses standard RS-232 links and 
is compatible with many stan- 
dard CRTs and software hosts. 
This includes Zilog's S8000 
systems, and others with user- 


OVERVIEW 


The Z-SCAN 8 Emulator is a com- 
bination of hardware and software 
that allows efficient,' interactive 
emulation of the Z8 Microcom- 
puter. By the Simple exchange of 
target devices, the selected Z8 
MCU can be emulated in a realistic 
mode that allows user inspection 
and control over the environment 


ZmSCAN $ 
!!1® li:lmUuBsn@U' 


i¥'lrc«il un ten 
lJJ)esa:riipftu@DU 
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supplied load/save routines and 
cross-software support. 


(J 
Hardware/software debugging 
is fast and convenient. Two 
screens display the status of 
the Z-SCAN 8 monitor and Z8 
target resources. Target m,em- 
ory can be displayed and mod- 
ified in a scrollable window. 


being tested. Real-time trace, two 
breakpoints, single-step capability, 
and extensive mappable memory 
ensure the user a tool that ac- 
curately simulates the anticipated 
Z8 operating environment. 


Z-SCAN 8 is an in-circuit emulator 
deSigned specifically for Zilog's 


a 
Fulfills the user's essential 
real-time debugging needs with 
its real-time trace, two com- 
plex breakpoints, single-step 
capability, and four blocks of 
mappable memory. 


g 
Interactive and easy to use. 
Commands are selected from 
menus; command arguments 
are self-prompting. 


Z8601 (2K), Z8611 (4K), and 
Z8681182 (ROMless) Microcom- 
puters. Z-SCAN 8 works with 
Zilog's family of development· 
hosts, interfacing via two RS-232 
serial ports to the host and a CRT 
terminal. A list of compatible CRT 
terminals is provided in Table 1. 
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Table 1. Terminals Supported by the 


Z·SCAN 8 Monitor 


Manufacturer 
Model 


Lear Siegler 
ADM31 


Televideo 
TVI 912 
TVI 920 


Zentec 
Zephyr 


So roc 
10120 
10135 


Beehive 
Bee 100 
Bee 107 
Micro-B 1 


DEC (any) 
VT52 
VT100 
ANSI A3.64 or 
ISO DP 6429 
compatible 


General Terminals, 1-200 
Inc. 
1-400 


Hazeltine 
1420 
1500 
Exec 80 


Hewlett Packard 
2620 
2640 


IBM 
3101 


Because it uses a standard serial 
interface, Z-SCAN 8 can also be 
use,d with virtually any software 
host system that runs a cross- 
assembler o'r cross-compiler 
capable of generating Z8 code (see 
Table 2). This means software can 
be developed on many general- 


FUNCTIONAl.. 
DESCRIPTION 


The Z-SCAN 8 emulator is a com- 
pact, portable device that can be 
used in,a wide variety of functional 
configurations and applications. It 
has been designed to ease debug- 
ging of both hardware and soft- 
ware, to integrate hardware and 
software in Z8-based systems, and 
to provide the user with a powerful 
and versatile tool for the develop- 
ment of new systems and new ap- 
plications for old systems. 
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Table 2. Recommended Sources for Cross·Software 


Source 
Description 


Zilog 
1315 Dell Avenue 
Campbell, CA 95008 
(408) 370-8000 


System 8000*. Cross-assembler for Z8 and 
Z8-UPC microcomputers. 


Third Party 


Allen Ashley 
395 Sierra Madre Villa 
Pasadena, CA 91107 
(213) 793-5748 


ASMB-Z8*. Cross-assembler; operates with any 
standard CP/M-based system. 
System-Z8*. Cross-assembler; includes ASMB- 
Z8 and text editor"operates with any standard 
CP/M-Z80-based system. 


Avocet Systems, Inc. 
804 South State St. 
Dover, DE 19901 
(302) 734-0151 


Z8 Cross-assembler (XASMZ8); operates with 
CP/M-80, CP/M-86, and MOOS. 


Microtec 
P.O. Box 60337 
Sunnyvale, CA 94088 
(408) 733-2919 


ASM Z8. Cross-assembler; operates with any 
general-purpose mainframe (DEC, IBM, DG, 
etc.) in FORTRAN .. 


Relational Memory 
Systems, Inc. 
P.O. Box 6719 


ASM Z8*. Relocatable macro cross-assembler; 
operates with Intel Intellec 800 and Series \I 
microcomputer development systems. 


San Jose, CA 95150 


·These Include the upload and download software for communicating. 


, purpose computers. Only a simple 
upload and download utility is 
needed for operation since com- 
munication between the host 
system and Z-SCAN 8 is through a 
standard serial port using Tektronix 
hex format. Once software has 
been downloaded into the target, 


The Z-SCAN 8 can be substituted 
for a Z8 microprocessor in any of 
its configurations or operational 
modes and can perform all the 
functions of the processor. Addi- 
tionally, the Z-SCAN 8 allows the 
user to 


II Control any function or opera- 


tion of the processor and its in- 
ternal (and in some cases, ex- 
ternal) hardware. 


Z-SCAN 8 can be disconnected 
from the host and operated stand 
alone. Transparent operation 
allows the terminal to be used with 
the host in such a way that 
Z-SCAN 8 effectively disappears 
from the terminal-to-host link, 
without any physical re-cabling. 


m Inspect and display the condi- 


tion or status of internal 
registers and CPU pins for up 
to 1,024 machine cycles 
preceding the breakpoint. 


II Execute a program or any 
number of instructions in single 
step mode. 


a 
Substitute up to 8K bytes of 
RAM for external program or 
data memory. 


TERMINAL 
RS·232 _r 
L 
t 
t 
DEBUG 
CONFIGURATION 
SCREEN 
SCREEN 


zaooo BOARD 


MONITOR 
PROGRAM 
(EPROM) 


Usor Interface, Z·SCAN 8 Com· 
mand Screens 


All communication between the 
user and Z-SCAN 8 takes place 
through the terminal. The format 
consists of two selectable screen 
menus: the Configuration menu 
and the Debug menu. The operator 
can manipulate each of these 
primary menus to enable variations 
for which the user can select a 
particular set of conditions, such 
as parameters and other variables, 
for.user control during ~mulation. 


Z-SCAN 8 executes two types of 
commands: screen commands and 
manipulation commands. The latter 
are used to control the display on 
the monitor and are normally exe- 
cuted by a control character or an 
arrow key. Screen commands are 
those used to define and control 
the conditions of an emulation. 


The Configuration Screen 


The Configuration screen is pri- 
marily used to inform the Z-SCAN 
80fcertain default values to be 
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Flguro 1. Z·SCAN 8 Systom Block Diagram 


used for a specific emulation. It is 
comprised of five submenus: 


[J 
Host 


[J 
Load 


[J 
Save 


[J 
Map 


[J 
Target 


These submenus allow the user to 


[J 
Set the host serial-link baud 
rate. 


[J 
Connect the user directly to 
the host system, in effect, mak- 
ing the Z-SCAN 8 transparent. 


[J 
Download programs or data 
from a host file. 


[J 
Allocate mappable memory in 
the Z-SCAN 8. 


[J 
Inform the Z-SCAN 8 of target 
configuration. 


In practice, the Configuration 
screen is seldom changed after Ini- 
tial setup until some other type of 
test or exercise is contemplated. 


The Debug Screen 


Because it controls those condi- 
tions most often changed, .the 
Debug screen is the scr.een most 
frequently entered during a series 
of tests or emulations. The Debug 
screen is comprised of five 
submenus: 


[J 
Watch 


13 
Memory 


'J! 
Break 


eXecute 


&I 
Display 


The Watch command allows the 
user to deSignate up to twelve 
16-byte lines of memory for 
display. This display is automat- 
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Figure 2. Bit Significance, Trace Memory Word 


ically updated to show any change 
occurring in the section of memory 
specified. 


The Memory command is used to. 
compare two blocks of memory, fill 
a block of memory with a hexa- 
decimal string, or move a block of 
memory to another range of ad- 
dresses. 


The Break command is used to 
define two complex breakpoints, 
which operate independently. 


The Display command allows the 
user to specify what portion or 
range of program, data, or register 
memory is to be displayed on the 
screen. 


SOFTWARE DESCRIPTION 


The basic design of the Z-SCAN 8 
software divides the emulator func- 
_ tions into two main tasks, the Net 
Task and the Command Task. The 
third major program module is the 


INTERFACE TO NON· 
ZILOG HOSTS 


Load/save communication between 
a Zilog (or other) host system and 
the Z-SCAN 8 monitor is ac- 
complished by exchanging 
messages containing printable 
ASCII characters. Message types 
are: 


11 
Single-character, data-block 
acknowledgment 
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Breakpoints 


Two complex breakpoints are 
available in the Z-SCAN 8. Each 


, breakpQint can be pr.ogrammed in- 


dependently to stop all processor 
activity at some arbitrarily selected 
point and save the state of the 
system in the trace memory for 
later analysis. The breakpoints may 
specify a stop on address, on data, 
or on a status such as an interrupt 
acknowledge. Or the breakpoint 
may specify that a pulse be 
generated and sent to the BNC 
connector at the back of the 
machine rather than stopping ,the 
emulation. 


Kernel, which performs the func- 
tions of an operating system. 


The two systel'Jl tasks are written 
in the C programming language. To 


• 
Error text 


• 
Data block 


All messages exchanged during a 
Load or Save command are text 
lines, each ending in RETURN (car- 
riage return}. Memory and other 


Trace Memory 


-The trace memory of the Z-SCAN 8 
consists of a 48-bit by 1 K block of 
RAM that can be used by the 
operator to record the condition 
and status of certain elements of 
the processor's environment for up· 
to 1,024 machine cycles. The trace 
memory can then be displayed and 
the display used' to analyze an en- 
tire series of steps in a routine. 
The bit significance of the 48-bit 
trace memory word is shown in 
Figure 2. 


Mappable Memory 


Mappable memory in the Z-SCAN 8 
consists of four 2K blocks of high- 
speed static RAM. Each of the 
blocks can be aSSigned in- 
dependently to replace a section or 
block of the target system's 
memory. The block can be a~­ 
signed anywhere in the Z8's 
memory space and can be 
specified to respond to program or 
data memory or both. Mapping 
must be done on 2K word bound- 
aries only, and the entire block can 
be write-protected. When a break 
results from a write-protect viola- 
tion, an error message appears on 
the CRT. 


take advantage of the system of 
pointers available in this language, 
the system sofhA/are has made ex- 
tensive use of tables that define 
the collection of system commands. 


data are converted into hexa- 
decimal numerals for transmission, 
and the resultant message is 
readable left-to-right, high-order 
digit first, as it is transmitted over 
the RS-232 link. 
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Z-SCAN 8 SPECIFICATIONS 


Processor: 


40-pin, 2K and 4K Z8 CPU 


Clock Rate: 


Internal to Z8000 board: 2.4 MHz 
Emulation Frequency: 
Up to 12 MHz 


I/O: 


Two RS-232-C serial ports for ter- 
, minal and host 
CRT Terinlnal: 
Any standard CRT system, including 
Zilog'8 S8000 systems. 
Baud Rato: 
Terminal: 


9600 
Host: 
Determined by user selection from 
300 to 38,000 


ORDERING INFORMATION 


Part No. 


05-0144-00 


Description 


Z-SCAN 8 Emulator 


Mappable Memory: 
8K high-speed, static RAM assign- 
able in 2K blocks 


Broakpolnts: 
Two com pies' breakpoint&: breakable 
on data, address, or !nt~rruPt 


acknowle~ge 


Emulator Cable; 
24 inches 
Front Panel: 
TARGET RESET and ~ONITOR RE- 
SET switches, POWER O~ indicator, 
40-pin connec;:tor type, 
Rear Panel: 
BNC connector for pulse output, 
standard LS-TTL level 2 x 25 pin con- 
nectors, 3M type '3483 (terminal and 


host), 3-pin power connector, 
1 ~ in., fuseholder (screwdriver re- 
lease type), POWER ON switch 
rocker type), 115/220 voltage selec- 
tion switch (sliding type) 
Power: 


180-264 volts ac or 90-130 volts ac, 
switch selectable; 47-63 Hz; 2 amp 
maximum 


Dlmen~lons: 


4 inch!3s x 17.5 inches x 14.5 inches 
(HWD); 10.2 centimeters x 44.5 cen- 
timeters x 36.8 centimeters 
Environment: 
1Qoe to 50 
0e (operating) 


Unit Weight: 
25 pounds 


.-a .. ,¢ .... ''''o,,''''-. .... ·.· ... 
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Zilog 


INTRODUCTION 


The Z-SCAN 800 is a low-cost 
Z800™ M PU development system 
designed to facilitate the integrated 
hardware and software develop- 
ment of Z800-based systems. The 
Z-SCAN 800 represents the logical 
choice for Z800 development, and 
offers Z80~ CPU system devel- 
opersthe ideal window to the 
future. 


H 
{'P!.~ 


Z-SCAN 800 
Z80C™ :;:iiiiila~oi 


Product 
Description 


'iSeptember 1983 


Based on Zilog's 16-bit Z8000™ 
CPU and connected via two RS- 
232-C compatible ports, the 
Z-SCAN 800 (Figure 1) offers in- 
circuit emulation (ICE) in a stand- 
alone mode or in a hosted multi- 
user configuration, using any of 
several common terminals and 
various host development systems. 


...., 
'1< 
" 
' 


; 
j;)%t 
; ~ l 
~ 
~ 


Figure 1. Z·SCAN 800 


The stand-alone mode is especially 
useful in manufacturing en- 
vironments as it provides simple 
testing and debugging for PROM- 
based target systems. Configured 
with a host, the Z-SCAN 800 
becomes transparent, lending itself 
to the development of high-level 
software. 
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Z·SCAN software offers similar 
flexibility. The user at a terminal 
has a choice of screens to view, 
and each screen offers a variety of 


options to enable the user to focus 
on specific needs. Real·time 
emulation, extensive trace capabil· 
ity, user·defined breakpoints, and a 


MUL TI·USER DEVELOPMENT 
SYSTEM WITH HOST 
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STAND·ALONE DEVELOPMENT 
SYSTEM 


TARGET 
BOARD 


RS 232 


INTERFACE 


I·SCAN 800 
IN CIRCUIT 
EMULATOR 
(ICE) 


Figure 2. Z·SCAN 800 Environment 


large mappable memory help main· 
tain the Zilog tradition of advanced, 
friendly development systems. 
Figure 2 illustrates the Z·SCAN 800 
environment. 


Z800 EMULATION 


The Z-SCAN 800 emulates all four 
characterized by an 8-bit, Z80-type 
The Z8116/8216 MPUs operate on 
versions of the Z800 MpU. These 
bus. The Z8108, a 40-pin package, 
the 16-bit Z-BUS@ . As with the 
four versions are the Z8108, 
includes on-chip the Z800-standard 
Z8108/8208 CPUs, the Z8116 con- 


Z8208, Z8116, and Z8216. All 
Memory Management Unit (MMU), 
tains the advanced features stan- 


Z800s are binary-code compatible 
clock oscillator, and refresh con- 
dard to the Z800s and the Z8216 


with the Z80, and incorporate ad- 
troller. The Z8208, a 64-pin 
includes the additional on-chip 
vanced architectural features such 
package, additionally includes four 
peripherals. 


as dual mode (User/System) opera- 
24-bit Direct Memory Access 
Regardless of the package type, 
tion, on-chip peripherals, and 
(DMA) channels, four 16-bit 
memory management. 
counter/timers, and a full-duplex 
the Z-SCAN 800 traces all address, 


UART to facilitate asynchronous 
data, status, and control signals on 
The Z8108/8208 MPUs are 
serial communication. 
Z800 pins for development with 
any Z800 MPU. 


MAPPABLE MEMORY 


N 
In addition to providing MPU 
ary. A special write-protection 
mappable memory as a complete 
• 
QPl 
emulation during system develop- 
feature can be individually applied 
substitute for eventual on-board 
n 
~ 


ment, the Z-SCAN 800 also 
to any combination of the eight 
ROM, or as a partial supplement to 
=- 
emulates user-board ROM by pro- 
blocks, providing a safe and ac- 
existing ROM. This supplement 
flO 


viding 64K bytes of static RAM. 
curate representation of system 
may represent additional ROM 
8 


This RAM may be divided in up to 
ROM. 
under development or even "throw 


eight blocks of 8K bytes each and 
The system developer can use the 
away" ROM to be used only during 
is mappable on any 4K byte bound- 
debugging. 


SCREEN·ORIENTED 
DISPLAY 


The screen-oriented display is one 
few hours by-interacting with the 
purpose and general-purpose 


example of the user-friendly soft- 
terminal display. The user chooses 
registers; target memory can be 
ware of the Z-SCAN 800. The 
between two screens: the· Debug 
displayed in scrollable fashion. 
screen-oriented approach frees the 
Screen and the Configuration 
user from the need to remember 
Screen. 
Configuration Screen 
all the possible commands 
The Configuration screen provides 
because the options are listed, and 
Debug Screen 
multiple options regarding the set- 
it eliminates time-consuming and 
The Debug screen acts as a "win- 
up of mappable memory. This 
error-producing keystrokes by re- 
quiring only cursor placement for 
dow" into the target. The user can 
screen contains information less 


selection. A first-time user can ef- 
configure the screen to display 
frequently used during the debug- 


fectively learn the Z-SCAN 800 ina 
preformatted presentations of 
ging phase, such as baud rates 
target resources such as special- 
and target characteristics. 


INTERFACE PROTOCOLS 
Table 1. Z·SCAN aoo Interface 


Protocols 


Z-SCAN 800 is provided with pro- 
developers to use their current 


tocols to permit uploading and 
hardware configuration as a host 
Host Operating 
zaoo Mode 


downloading with many host com- 
for Z-SCAN development work. In 
System 
Protocol 


puter systems. Protocols are pro- 
addition, protocols are provided to 
Apple 
Special 
vided for the Z800 family running 
allow Z-SCAN 800 to interface with 
under several operating systems 
such popular terminals as 
CP/M 
ELOAD-binary 


as shown in Table 1. These stan- 
ADM-31 s, Hazeltine, HP and many 
Intel MDS 
ELOAD-binary 
dard protocols allow system 
more. 
System 8000, ZEUS 
ELOAD·binary 
Vf\)(, UNIX* 
ELOAD·binary 


·UNIX is a registered trademark of Western Electric 
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BREAKPOINTS 


The Z-SCAN 800 provides two 
complex hardware breakpoints and 
fifteen software breakpoints. The 
two hardware breakpoints permit 
the user to break on address, data, 
and control signals, and can cause 
breaks on specific combinations of 
conditions. The additional software 


TRACE 


Another invaluable tool for debug- 
ging is the trace feature. Trace 
records up to 64-bits of data on up 
to 1000 events, creating clear 
histories. of Z800 signal states. 


·UNIX is a trademark of Bell Laboratories. Zilog is 
licensed by AT&T. 
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breakpoints contribute to making 
debugging a relatively simple task. 


Additionally, the Z-SCAN 800 incor- 
porates a break-in/break-out 
feature, extremely useful in a Local 
Area Network (LAN) debugging 
situation. Break-in and break-out 


Finally, a disassembler provides 
the user with easily recognizable 
mnemonics to interpret results. 


And the Z-SCAN 800 is an excep- 
tional value. It comes at a very low 


pulses allow simultaneous breaking 
within a multiple Z-SCAN environ- 
ment. The break-in signal may 
come from an external source or it 
may originate in a previously set 
hardware breakpoint within a 
Z-SCAN 800. 


cost and includes a pod to ensure 
reliable results even with high fre- 
quencies and long cables. The 
Z-SCAN 800 is fully UUCSA ap- 
proved. 


00-2261.()1 


Zilog 


iii Provides Real Time Emulation up 


to" MHz of tho Z8DDI and Z8002 
CPUs. 


iii Two RS-232C Serial Ports Make It 
a Peripheral Usable with MQst 
Standard CRTs and Software 
Hosts. 


'OVERVIEW 


The Z-SCAN 8000 Emulator is an in- 


circuit emulator that has been designed 
as a peripheral unit for Zilog's Z8001 
and Z8002 16-bit microprocessors. 
InterfaCing via two RS-232C Serial 
ports to host and CRT terminal, 
Z-SCAN 8000 can work with Zilog's 
family of development hosts. 
Because it employs a standard serial 
interface, Z-SCAN 8000 can also be 
used with Virtually any software host 
system that runs a cross assembler or 
cross compiler capable of generating 
Z8000 code. Communication between 
the host system and Z-SCAN 8000 is 
with a standard serial format requiring 


Z8000™ Emulator 
!gSCAtJ 8000 


Product 
Description 


September 1983 


II Transparent Operation Permits 
Direct Communication Between 
CRT and Host without Physical 
Disconnect. 


C Highly Interactive. Screen- 
Orientod User Interface Makos 
Z-SCAN Easy To Use. 


only a simple upload and download 
utility to operate. For PROM-based 
target systems, Z-SCAN can operate 
stand-alone with' a CRT terminal 
because the monitor and debug soft- 
ware is EPROM-resident: 
In keeping with Zilog's design 
philosophy of separating a develop- 
ment system into two identifiable units 
(the software host and an emulation 
peripheral), Z-SCAN 8000 fits into 
three scenarios, making it a highly ver- 
satile unit: 
II As a periph~ral to Zilog's PDS 8000, 
ZDS-1, or System 8000, Z-SCAN 
8000 completes the development 


II Shadow Monltor Removes All 
Restrictions on Targot Syntom 
Memory Space. Makin!} It Fully 
Available To the User. 
m High-Speed Mappable Memory 
(no wait states) Is Avallablo to 
,Simulate Target System 
RAM/ROM. 


support package for the' Z8001 and 
Z8002 microprocessors available 
from Zilog. 


II As a peripheral to any development 
host with the capability of compiling 
or assembling Z8000 code, Z-SCAN 
8000 allows a low-cost emulation 
capability which precludes substan- 
tial reinvestment in a software host 
system. 


I! As a stand-alone in-circuit emulator 
that can operate with ~ost CRT 
terminals, Z-SCAN 8000 provides 
simple testing and debugging 
capability for PROM-based target' 
systems. 
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SYSTEM FEATURES 
User Interface. Z-SCAN SOOO incor- 
porates the use of a two-dimensional 
screen-oriented user interface which 
'makes it easy to use. Because it is 
general-purpose in nature, the user 
interface does not require a customized 
CRT terminal to operate. The only 
requirements are that the CRT terminal 
have screen erase, line erase, and cur- 
sor addressing capability. 
The objective of the user interface is 
to provide a screen format with a 
menu-like approach, which directs the 
user through the operation of the emu- 
lator. The user is aware at all times of 
where he/she is in the debug process 
because Z-SCAN 8000 provides the 
CRT information about system para- 
meters, system resources, current 
execution, and error messages. When 
the system is turned on, a bootstrap 
routine produces a display informing 
the user of the unit's configuration and 
requesting the user to define set-up 
parameters. A menu of display choices 
shows the user the different capabilities 
of the system: 


• The Memory/I/O command display 
shows the various memory and I/O 
manipulation commands which 
access the target system. 


• The Resources display presents the 
user with the full complement of 
arguments applicable to emulation 
of the target system~ 


• The Execution display shows all the 
commands and parameters neces- 
sary to cause emulation to take 
place. 
At all times, execution of specific 
Monitor commands is possible, and 
information on other relevant system 
parameters and resources is always dis- 
played. This highly interactive user 
interface makes it possible to usa 
Z-SCAN 8000 without frequent 
reference to the operating manual. 


Shadow Memory. Z-SCAN 8000 is a 
single, CPU-based systepl that can be 
configured to emulate either the 28001 
or Z8002 by simply exchanging the 
CPU, monitor EPROM, and the 
emulator cable. 
Although the system uses a single 


CPU for both monitor and emulation 
functions, no restrictions are placed on 
the target system memory size. This is 
because the entire monitor resides in 
shadow memory and, therefore, does 
not appear in the target system memory 
space. This feature also provides the 
benefit of making future system expan- 
sion possible without any hardware 
redesign. ' 
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ADDRESS/DATA 
BUS 


ADDRESS/DATA 
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SEGMENT 
COMPARATORS 
STATUS 
COMPARATORS 


DON'T 
CARE 


INSTRUCTION 
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DETECT 


COUNTER 


MATCH 


COUNTER 


Figure 1. Hardware Trigger Implementation 


Hardware Trigger. Z-SCAN 8000 
offers the capability of setting break- 
points in three different fields or in a 
combination of these fields. These are 
the Address/Data Field, the Segme.nt 
Field, and the ControVStatus Field. A 
Pass Counter can be set up to a max- 
imum of 255 counts to allow multiple 
pass triggering. In addition, Z-SCAN 
8000 may also be set to break on 
instruction fetches only (single-step 
execution), or, by using a Pass 
Counter, may be set up to a maximum 
of 247 counts to allqw triggering on 
multiple instruction 'fetches (multi-step 
execution) . 
With these two capabilities, a break- 


point argument can be set up which is 
on ORed condition allowing for either 
a break-on-field (or combination of 
fields) argument or for "n" instruction 
fetches, whichever occurs first. This 
ORed situation is convenient when 
tracing through a program in search of 
a'specific occurrence. A pulse output, 
providing a trigger pulse on break- 
point match condition is available on 
the rear panel to trigger auxiliary test 
instrumentation. 


Mappable Memory. Z-SCAN 8000 
offers a 4K work block of high-speed 
static RAM. This block is available to 
the user to simulate a target system 


memory block which would typically 
be ROM. No Wait states are required 
at 4 MHz. This block is mappable 
anywhere in the 28001 and 28002 
address space and can be speCified to 
be Normal Code, Normal Data, Normal 
Stack, System Code, System Data, 
System Stack, -or Space Independent. 
Mapping must be done on 4K word 
boundaries only, and the entire block 
can be write protected against illegal 
writes to cause system emulation either 
to break on such occurrences or con- 
tinue emulation. An error message 
appears on the CRT display informing 
the user of an illegal write. 
Software Trace. Z-SCAN 8000 bffers a 
software trace feature which provides 
insight into target system activity and 
CPU resources. In the Trace Mode, the 
system displays the address of the 
instruction being executed and the 
contents of the CPU registers (both 
general-purpose and control) con- 
secutively, covering one full screen 
format. 
For example, displaying the CPU 


registers associated with every instruc- 
tion executed just prior to executing a 
Break is tremendously useful to the 
user during debug of target system 
activity. 
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SPECIFICATIONS 


CPU 
28001 or 28002 per configuration 


Clock Rato 


500 kHz-4.0 MHz (external) 


110 


Two RS-232C Serial Ports for CRT and 
host 


Baud Rato 
Automatically selected from 50 to 19.2K 


Breakpoint 
Address, Data, Segment and Address, 
Control, Address and Control, Data and 
Control, Segment and Address and 
Control, Instruction Fetch, OR combina- 
tion of Instruction Fetch and any Field 
argument 


AC CHARACTERISTICS 


Numb::: 


Mappablo Momory 


4096 X 16 Static RAM (no Wait states at 
4 MHz while operating off User clock) 


Inputs 


One standard LS-TTL load plus 30 pF 
maximum 


Outputs 


Capable of driving one standard LS-TTL 
load plus 30 pF preload 


Rear Panol Output 


ENC connector for pulse output, standard 
LS-TTL 


Front Panol 


Target/Monitor, Reset, and NMI toggle 
switches 


Power 
110/220 Vac, 50/60 Hz switch selectable, 
60 V A maximum 


Dimensions 
4 in. (10.2 cm) (H) X 14Y2 in. (36.8 cm) 
(W) X 18 in. (45.7 cm) (D) 


Emulator Cablo 
12 inches 


ZCOO1l2 
Z-SC1Ui 


Symbol 
Paramoter 
Min{nu) 
Max{ns) 
Min{ns) 
Max{ns) 


1 
TcC 
Clock Cycle Time 
250 
2000 
250 
2000 


2 
TwCh 
Clock Width (High) 
105 
2000 
105 
2000 


3 
TwCl 
Clock Width (Low) 
105 
2000 
105 
2000 


4 
TfC 
Clock Fall Time 
20 
20 
5- TrC 
Clock Rise Time------------------- 20 
20- 


6 
TdC(SNv) 
Clock t to Segment Number Valid (50 pF load) 
130 
175 
7 
TdC(SNn) 
. Clock t to Segment Number Not Valid 
20 
35 
8 
TdC(Bz) 
Clock t to Bus Float 
65 
165 
9 
T dC(A) 
Clock t to Address Valid 
100 
163 
10- TdC(Az)---Clock t to Address Float --------------- 65 
154- 
11 
TdA(DI) 
Address Valid to Data In Required Valid 
455 
383 
12 
TsDI(C) 
Data In to Clock , Setup Time 
50 
76 
13 
TdDS(A) 
DS t to Address Active 
80 
-4 
14 
TdC(DO) 
Clock t to Data Out Valid 
100 
163 
15-ThDI(DS)--- Data In to DS t Hold Time ----------- 0 
-20 


16 
TdDO(DS) 
Data Out Valid to DS t Delay 
295 
269 
17 
T dA(MR) 
Address Valid to MREQ , Delay 
55 
29 
18 
TdC(MR) 
Clock' to MREQ , Delay 
80 
143 
19a 
TwMRh 
MREQ Width (High) 
210 
193 
19b-TwMRh 
MREQ Width (High) During Monitor Operation------------- 184 


20 
TdMR(A) 
MREQ , to Address Not Active 
70 
53 
21 
TdDO(DSW) 
Data Out Valid to DS , (Write) Delay 
55 
59 
22 
TdMR(DI) 
MREQ' to Data In Required Valid 
350 
287 
23 
TdC(MR) 
Clock' MREQ t Delay 
80 
134 
24-TdC(ASf)--Clock t to AS J Delay---------------- 80 
134- 
25 
TdA(AS) 
Address Valid to AS t Delay 
55 
29 
26 
TdC(ASr) 
Clock' to AS t Delay 
90 
144 
27 
TdAS(DI) 
AS t to Data In Required Valid 
340 
277 
28 
TdDS(A~) 
DS t to AS , Delay 
70 
53 
29-TwAS 
AS Width (Low)------------- 70 
53 


30 
TdAS(A) 
AS t to Address Not Active Delay 
60 
43 
31 
TdAz(DSR) 
Address Float to DS (Read) , Delay 
0 
-41 
4 
--------------------------------CONTINUED ON NEXT PAGE----------------------------- 
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AC CHARACTERISTICS 


Number 
Z8001/2 


Symbol 
Parameter 
Min(ns) 
Max (ns) 


32 
TdAS(DSR) 
AS t to DS (Read) 1 Delay 
70 


33 
TdDSR(DI) 
DS (Read) .!...!.O Data In Required Valid 
185 
34 
TdC(DSr) 
Clock 1 to DS t Delay 
35 
TdDS(DO) 
DS t to Data Out and STATUS Not Valid 
75 
36-TdA(DSR) -- Address Valid to DS (Read) 1 Delay 
180 


37 
TdC(DSR) 
Clock t to DS (Read) 1 Delay 
38 
TwDSR 
DS (Read) Width (Low) 
275 
39 
TdC(DSW) 
Clock 1 to DS (Write) 1 Delay 


40 
TwDSW 
DS (Write) Width (Low) 
185 
41-TdDSI(DI)-- DS (lnput)..!J.o Data In Required Valid 
320 


42 
TdC(DSf) 
Clock 1 to DS (I/O) 1 ,Delay 


43 
TwDS 
DS (I/O) Width (Low) 
410 
44 
TdAS(DSA) 
AS t to DS (Acknowledge) 1 Delay 
1065 


45 
TdC(DSA) 
Clock t to DS (Acknowledge) 1 Delay 
46-TdDSA(DI)-- DS (Acknowledge) 1 to Data In Required Delay---435 
47 
TdC(S) 
Clock t to Status Valid Delay 
48 
TdS(AS) 
Status Valid fa AS t Delay 
49 
TsR(C) 
RESET to Clock t Setup Time 


50 
ThR(C) 
RESET to Clock t Hold Time 
51-TwNMI 
NMI Width (Low) 
52 
TsNMI(C) 
NMI~ 
Clock t Setup Time 
53 
TsVI(C) 
VI, NVI to Clock t Setup Time 
54 
ThVI(C) 
VI, NVI to Clock t Hold Time 
55 
TsSGT(C) 
SEGT to Clock t Setup Time 
56-ThSGT(C)-- SEGT to Clock t Hold Time 
57 
TsMI(C) 
MI to Clock t Setup Time 
58 
ThMI(C) 
MI to Clock t Hold Time 
59 
TdC(MO) 
Clock t to MO Delay 


60 
TsSTP(C) 
STOP to Clock 1 Setup Time 


61-ThSTP(C)--.STOP to Clock 1 Hold Time 
62 
TsWT(C) 
WAIT to Clock 1 Setup Time 
63 
ThWT(C) 
WAIT to Clock 1 Hold Time 
64 
TsBRQ(C) 
BUSREQ to Clock t Setup Time 
65 
ThBRQ(C) 
BUSREQ to Clock t Hold Time 
66-TdC(BAKr)--Clock t to BUSACK t Delay 
67 
TdC(BAKf) 
Clock t to BUSACK 1 Delay 


ORDERING INFORMATION 


Part No. 
Description 


05-0100-00 
Z-SCAN 8000/1 Emulator 
(Supports Z8001 Emula- 
tion and Control) 


05-0100-01 
Z-SCANBOOO/2 Emulator 
(Supports Z8002 Emula- 
tion and Control) 


05-0101-00 
Z8001 Field Support Kit 
(Converts Z-SCAN 
BOOO/2 into Z-SCAN 
BOOO/1) 


05-0102-00 
Z8002 Field Support Kit 
(Converts Z-SCAN 
BOOOIl into Z-SCAN 
BOOO/2) 


05-0103-01 
Z-SCAN BOOO Emulator 
Includes Z8001 and 
Z8002 CPU's, emulator 
cables and serial inter- 
face cables; 
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Systems ,recommended: 
I 


Description 


ZDS-l Series Development Systems 


PDS 8000 Series Development 


Systems 


System BOOO Family 


60 
180 
0 
100 
140 
110 
0 
70 
0 
180 
0 


140 
0 
50 
10 
90 
10 


70 


120 


95 


, 120 


120 


110 


120 


100 
100 


Prerequh;i tes 
zaooo SDP 


Z8000 SDP 


zaooo SDP 


Z-SCAN 


Mln(ns) 
Max (ns) 


53 
122 
65 
58 
154 
174 
258 
149 
168 
266 
174 
393 
1048 


174 
381 
162 
45 


208 


15 
116 
154 
118 
22 
78 
22 
188 
22 
165 
148 
22· 
78 
25 
98 
32 
145-- 
145 
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Features 


IJ 
VLSI components include the 6 
MHz Z8001A CPU and 6 MHz 
Z8010A Memory Management 
Units (MMUs), as well as 6 
MHz Z80B CPUs. The Z8000 is 
a 16-bit CPU that has 16 
general-purpose registers, an 
8M byte address space, and 
capability to perform 8-bit, 
16-bit, and 32-bit operations. 


o 
ZEUS, Zilog's enhanced UNIX* 
operating system, is a com- 
plete, real UNIX, not a look- 
alike. Enhancements include 
additional utilities from Zilog 
and the University of California 
at Berkeley. 


[J 
System 8000 uses a powerful 
screen-oriented text editor to 
increase editing spe'ed. 


[J 
A selection of high-level 
languages is offered for the 
Z8000: BASIC, COBOL, C, 
FORTRAN 77, Pascal and 
PLZ/SYS. 


[] Up to 4M bytes of ECC- 
controlled memory increases 
system reliability, and a large 
physical memory size improves 
system performance. 


IJ 
Up to 24 users can be sup- 
ported. 


[] Optional industry-standard 
9-track, half-inch, magnetic 
tape is available for informa- 
tion interchange. Streamer 
mode is used for disk backup. 
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H igh·Performance, 
Time.Sharing 
Computer Systems 


The System 8000 Models 21 and 
31 are general-purpose, multiuser, 
time-sharing computer systems. 
They offer versatile and economic 
solutions for the commercial user, 
since many users can be added to 
the same system, all performing 
different tasks simultaneously. 
Sharing of files and transmission of 
messages between users is easy. 
The multiuser programming en- 
vironment allows both 
sophisticated and untrained users 
to operate the computer. 


State·of·the·Art Technology Plus 
Future Expansion 


For optimal performance, the 
System 8000 utilizes many ad- 
vanced components such as 


Z8000TM CPU, ECC (Error Checking 
and Correction controlled memory, 
Winchester disks, cartridge tape 
and low power consumption 
devices. System growth is made 
possible by the addition of more 
boards and more peripheral 
modules. 


As a supplier of both components 
and systems, Zilog incorporates 
the latest microprocessor 
technology into system-level' 
products. 


The System 8000 family offers 
high-performance systems at 
reasonable' cost. 


'UNIX is a trademark of Bell Laboratories, Zilog is licensed by Western ElectriC, Inc. for the Seventh Editon and System III. 
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Left to Right: Model 11, Model 31 with Optional 
Expansion Chassis. Model 31 with Optional 
g·Track Tape Drive. Model 21. 


Software 


For the operating system, Zilog 
chose to implement UNIX, the op- 
timum environment for application 
software development and pro- 
grammer productivity. The Zilog 
"port" of UNIX is named ZEUS, for 
Zilog Enhanced Unix System. It 
contains many additional features 
and utilities designed by Zilog and 
the University of California at 
Berkeley. 


Unlike some other implementations 
of the popular UNIX operating 
system, ZEUS, in conjunction with 
the Z8001 CPU and the specialized 
memory management hardware in 
the System 8000; is able to support 
extremely large user programs. 
This can be especially important 
for large FORTRAN and C applica- 
tions. 


ZEUS is a general-purpose, 
multiuser, multitasking operating 
system designed for software 
development. Productivity in- 
creases with ZEUS because with 
it, the necessary software tools are 
available. Documentation quality . 
and availability also improve 
because tedious jobs are 
automated. 
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All of the software needed to make 
system programmers, application 
programmers, and technical 
writers more productive is 
available on the system. Commer- 
cial users can choose from COBOL 
and BASIC business languages; 
system programmers have C, 
Z8000 assembler, and PLZ/SYS for 
their needs. Technical users can 
select FORTRAN 77 or Pascal. 


Programs for business such as Ac- 
counts Receivable, Payroll, and 
Order Entry can be quickly ported 
and customized. In the technical 
environment, special software and 
test programs can be developed to 
fit the needs of the task. The major 
operating system features are: 


• 
Hierarchical file system 


• 
Compatible file, device, and 
interprocess input/output 


• 
Separate code and data 
address space 


• 
Multiple processes per user 


• 
User configurability 


• 
User programs address space 
of up to 8M bytes (C, 
FORTRAN 77, assembler) 


System Utilities 


The system utilities include the 
command interpreter and file 
maintenance, status inquiry, 
system accounting programs, and 
data communications. The com- 
mand interpreter is selected on a 
per-user basis, enabling the system 
to be tailored to the needs of dif- 
ferent users. Data communications 
utilities are included for networking 
over a serial link to other local or 
remote ZEUS- or UNIX-based com- 
puter systems. 


The ZEUS programming tools con- 
sist of languages, libraries, a sym- 
bolic debugger, text processing 
software, and more than 180 other 
utilities. 


Hardware 


The System 8000 hardware is 
designed to support ZEUS soft- 
ware. The memory management 
architecture allows ZEUS to sup- 
port, with minimal changes, pro- 
grams that run under the UNIX 
operating system. The memory ar- 
chitecture also makes it possible 
for user programs to have an ad- 
dress space of up to 8M bytes. 


DeSigned for performance, reliabil- 
ity, and future growth, System 
8000 is based on Zilog's 6 MHz 
Z8001A CPU, with high- 
performance, high-reliability Win- 
chester and Storage Module Disks 
(SMD). Intelligent I/O controllers 
aid performance. The large ECC- 
controlled memory reduces swap- 
ping. The ZeBUS Backplane Inter- 
connect (ZBITM) and modular 
system packaging allow for system 
growth. Serial RS-232-C and 
parallel interfaces allow attach- 
ment of I/O devices such as CRTs 
and printers. 


The modular design makes System 
8000 easy to service. As many as 
five modules can be stacked. Each 
module is self-contained so that 
modules can be unstacked without 
tools. The unit can also be 
mounted in a standard 19" rack. 


Zilog is committed to the long-term 
development of the System 8000 
product family. A recent addition is 
an industry-standard, half-inch 
magnetic tape peripheral option. 
This peripheral supports inter- 
change of information on tape with 
other systems and can also be 
used in a "streaming" mode for 
fast·, high-capacity backup of the 
on-line disks. 


System 8000 Model 21 and 31 Characteristics 


Physical 
Height 
Width 
Depth 
Weight 


84 cm (33 in.) 
48 cm (19 in.) 
61 cm (24 in.) 
105 kg. (250 pounds) 
approximate 


Winchester Disk Performance 
Rotation Speed 
3,600 RPM 
Power ON to Ready , 
60 seconds 
Time 
Average Positioning 


Time (Typical) 
Number of Surfaces 
Tracks per Surface 
, Sectors per Track 
Bytes per Sector' 
Data Transfer Rate 
Capacity Unformatted 
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45 ms 


4 
600 
24 
512 
801 K bytes/sec 
32M bytes 


Storage Module Disk (SMD) Performance 
Rotation Speed 
3,600 RPM . 
Power ON to Ready Time 60 seconds 
Average Positioning Time 
(Typical) 
Number of Surfaces 
Tracks per Surface 
Sectors per Track 
Bytes per Sector 
Data Transfer Rate 
Capacity Unformatted 


Environmental 
Operating Temperature 


Relative Humidity 


20 ms 
7 
589 
32 
512 
1.2M bytes/sec 
84M bytes 


10° C 
(50 0 F) min. 
40° C 
(104° F) max. 
20-80% 
(noncondensing) 


Cartridge Tape Drive Performance 


Speed Read/Write 
30 ips (90 ips) 
(rewind/search) 
Tracks 
Recordi[Jg Density 


Memory 


4 
6,400 BPI 


1 M bytes ECC (minimum) 


Electrical 
. Phase 


Frequency 


Nominal 
Selectable 
Voltages ( ±,1 0 %) 


100 V ac/60 Hz 
117 V ac/60 Hz 
220 V ac/50 Hz 
240 V ac/50 Hz 


Single 
47-63 Hz 


Current 
Sustained 
(max) 


5.0 A 
5.0A 
2.5 A 
2.5 A 


Current 
Surge 
(max) 


8.0 A 
8.0A 
4.0 A 
4.0 A 
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Features 


• 
Economical, time-sharing 
system supports up to eight 
users. 


• 
Powerful ZEUS operating 
system, Zilog's implementation 
of UNIX*. 


• 
ZEUS includes a screen- 
oriented text editor and com· 
prehensive text processing 
software for fast and easy 
editing applications. 


• 
Model 11 supports such high- 
level languages as COBOL, 
BASIC, C, PLZ/SYS, FORTRAN 
77, and Pascal. 


• 
Up to 1 M bytes of parity 
memory or optional 1 M byte of 
ECC-controlled memory. 


• 
Up to 36M bytes of disk 
storage capacity. 


• 
17M byte cartridge tape for 
backup and archiving. 


A Compact Computer Powerful 
Enough to Support Eight Users 


The Zilog System 8000 Model 11 
has been specifically designed for 
business and office environments. 
The system is small enough to fit 
under a desk, yet can provide com- 
puting power for up to eight users 
simultaneously. This general- 
purpose, time-sharing system is 
ideally suited for commercial 
needs. 


System 8000 
Moden I! 


Product Brie! 


September 1983 


State-of-the-Art Components 


The Model 11 features reliable, 
field-proven VLSI components such 
as the Z8001A CPU (which sup- 
ports separate code and data ad- 
dress spaces) and three Z801 OA 
Memory Management Units. 


The basic Model 11 has 256K 
bytes of parity random-access 
memory (RAM). A 51A -inch. Win- 
chester disk provides IBM bytes of 
storage. The sealed, high- 
performance Winchester disk drive 
protects data from contaminants 
. and provides economical, fast, and 
highly reliable on-line storage of 
data. 


A 17M byte cartridge tape drive is 
used for hard disk backup. This 
tape drive offers virtually unlimited 
off-line storage of data. 


Powerful ZEUS Operating 
System 


For the operating system, Zilog 
chose to implement UNIX, the op- 
timum environment for application 
software' development and pro-' 
grammer productivity. The Zilog 
"port" of UNIX is named ZEUS, for 
Zilog Enhanced Unix System. 


Unlike some other implementations 
of the popular UNIX operating 
system, ZEUS, 'in conjunction with 
the Z8001 CPU a'nd the specialized 
memory management hardware in 
the System 8000, is able to support 
extremely large user programs. 
This can be especially important 
for large FORTRAN and C applica- 
tions. 


·UNIX is a trademark of 8ell Laboratories, Zilog is licensed by Western Electric. Inc, for the Seventh Edition and System III. 
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ZEUS includes features and addi- 
tional software developed by Zilog 
and the University of California at 
Berkeley. Major features of the 
ZEUS operating system are its 
hierarchical file structure and com- 
patible file, device, and inter- 
process input/output functions. 


ZEUS includes an impressive array 
of programs that comprise its 
system utilities and development 
tools. These software tools make it 
easy for both OEMs and end-users 
to develop new applications 
quickly. 


Reliable Hardware 


The system's hardware has been 
designed to complement its power- 
ful software. Also, programs 


developed on other units in the 
System 8000 family are completely 
transferrable to the Model 11. 


Intelligent Winchester disk and 
tape drive controllers free the 
operating system from routine 
device-handling functions. 


The system's 32-bit Z-BUS 
Backplane 'Interconnect (ZBITM) 
provides flexibility in system con- 
figuration and allows for future ex- 
pansion. 


Serial RS-232-C and parallel inter- 
faces allow the system to com- 
municate with input/output devices 
such as CRTs and printers. 


Flexible Hardware 
Expansion 


To accommodate system growth, 
the basic Model 11 System 8000 
can be expanded to include up to 
1 M bytes of parity or ECC- (Error 
Checking and Correction) con- 
trolled memory. A second 51A -inch, 
IBM byte Winchester disk drive 
can be added to the system to pro- 
vide dual drives with a total of 36M 
bytes of on-line data storage 
capacity. 


System Utilities 


The ZEUS system utilities provide 
programs for user access, com- 
mand processing, file manage- 
ment, status information, com- 
munication with other devices or 
systems, and system maintenance. 


System 8000 Model 11 Characteristics 


Physical 
Environmental 


Height 
66 cm (26 in.) 
Operating Temperature 
10° C 


Width 
20 cm (8 in.) 
(50° F) min. 
Depth 
46 cm (18 in.) 
40° C 


Weight 
43 kg. (95 pounds) 
(104° F) max. 
approximate 
Relative Humidity 
20·80% 


Winchester Disk Performance 
(noncondensing) 


Rotation Speed 
3,600 RPM 
Cartridge Tape Drive Performance 
Power ON to Ready Time 60 seconds 
Speed Read/Write 
30 ips (90 ips) 
Average POSitioning Time 
(rewind/search) 


(Typical) 
75 ms 
Tracks 
4 
Bytes per Sector 
512 
Recording Density 
6,400 BPI 


Data Transfer Rate 
5M bits/sec 
Memory 
Capacity Unformatted 
IBM bytes 
256K-byte parity (minimum) 
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ZEUS features a command inter- 
preter as an interface between the 
user and the system. It is selected 
on a per-user basis, allowing the 
system to be tailored to meet the 
needs of different users. 


The ZEUS development tools in- 
clude programming languages, 
libraries, a symbolic debugger, text 
processing and formatting soft- 
ware, and more than 180 other 
utilities. ZEUS also includes a two- 
dimensional, screen-oriented text 
editor to increase editing speed. 


The system supports several high- 
level programming languages for 
business, scientific, and industrial 
applications. Choose from COBOL, 
BASIC, C, PLZ/SYS, FORTRAN 77, 
and Pascal. 


Left to Right: Model 11, Model 31 with Optional 
Expansion Chassis. Model 31 with Optional 
g-Track Tape Drive. Model 21. 


Electrical 


Phase 
Single 


Frequency 
47·63 Hz 


Nominal 
Current 
Current 


Selectable 
Sustained 
Surge 
Voltages (± 10%) 
(max) 
(max) 


100 V ac/60 Hz 
2.5 A 
4.0 A 
117 V ac/60 Hz 
2.5 A 
4.0 A 


220 V ac/50 Hz 
1.25 A 
2.0 A 


240 V ac/50 Hz 
1.25 A 
2.0 A 
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Software 


Development 
Products 


. Zilog 


Pioneering the 
Micro world 


Zilog OTTers full support for all 
its microprocessors and micro- 
computers with the System SOOO. 
The System SOOO computer 
system uses ZEUS, the UNIX*- 
based operating system specific- 
ally designed for software 
development and text processing. 
Numerous development tools are 
available, including the program- 
ming languages PLZ/SYS, C, 
FORTRAN 77, Ada, and Pascal; 
various libraries; and a symbolic 
debugger. 
Cross-software packages run 
under ZEUS on the SSOOO enable 
complete code development for 


·UNIX is a trademark of Bell Laboratories. 


Development Systems 


ao~iware ~or 
All lilog Microprocessors 


all Zilog microprocessors and 
microcomputers. This includes C 
compilers for the ZSOOO and ZSO 
and assemblers for the ZSOOO, 
ZSOO, ZSO, and ZS. 


Emulators designed for the 
complete range of Zilog products 
are detailed in the Development 
Section of this data book. 
Because ZEUS treats emulators 
as System SOOO peripherals, 
System SOOO can be combined 
with EMS SOOO, Z-SCAN SOOO, or 
with non-Zilog emulators to pro- 
vide total product development 
support for multiple micro- 
processors. 


The ZRTS Kernel is a small ex- 


ecutive program that provides the 
core of a real-time multitasking 
operating system in PROM able 
form. In addition to development 
languages, ZRTS SOOO and ZCL 
are available to assist the user in 
implementing a real-time target 
operating system. ZCL is a high- 
level configuration language that 
permits the designer to c'onfigure 
the target system in easy-to-use 
statements. 
More software products for 
Zilog components and systems 
are described in the Zilog Soft- 
ware Catalog. 
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Features 
• High-level procedure-oriented language 
permits efficient writing of machine- 
independent modules and programs. 


• Structured format for fast and easy-to- 
compile programs. 


• Produces efficient code for economical 
memory usage and processing time. 


Description 
28000 PLZ is a family of different program- 
ming languages designed to satisfy a wide 
range of microcomputer software development 
requirements. The two members of the PLZ 
family, PLZlSYS and PLZlASM, produce object 
code-compatible modules and share common 
control structures and data definition facilities. 
Thus, selective portions of programs can be 
written in the most appropriate language for 
the speCific application and still maintain a 
consistent structure between modules. 
PLZlSYS is a high-level, procedure-oriented 
language that is syntactically similar to Pascal. 
It provides a medium for writing structured, 
machine-independent programs with a 
minimum of programming effort. 
PLZI ASM, on the other hand, is a structured 
assembly language that permits access to the 
low-level capabilities of the processor by mix- 
ing assembly language and high-level control 
structures. 


Compiler. The Z8000 PLZlSYS Compiler 
translates source code modules into an 
intermediate stage called Z-code. The Z-code 
modules can then be executed interpretively or 
processed by the code generator to produce a 
machine-code object module. 
The compiler provides support for both the 
segmented and non-segmented 28000 pro- 
cessors. 


Code Generator. The Z8000 PLZCG Code 
Generator accepts a file of intermediate Z-code 
generated by PLZlSYS and produces the cor- 
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PL~/SYS 


Product 
Brief 


June 1982 


• Simplifies software production and 
maintenance. 


I!I Allows direct or interpretive execution of 
program modules. 


&1 Supports both segmented and nonsegmented 


Z8000 processors. 


responding Z8000 machine code as a relocat- 
able object module. This file can be linked 
with other modules to form a complete 
executable load module. 


Interpreter. The intermediate Z-code modules 
produced by the Z8000 PLZlSYS Compiler can 
be executed interpretively by ZINTERP. Link- 
ing ZINTERP with the other modules generated 
by the compiler produces an executable load 
-module. 


Linker. The Linker, ZLINK, links Z-code, 
ZINTERP and/or machine code modules into a 
single relocatable load module, allOWing the 
user to control the overall size and speed of 
the program. 
Although interpretive Z-code runs more 
slowly than machine code, the space savings 
over machine code is usually substantial for 
larger programs where the 3K bytes of 
ZINTERP is a small percentage of the entire 
program. By balancing the number of Z-code 
and machine code modules, the user can max- 
imize the efficiency of a particular program. 


ZLINK resolves any external references 
between separately assembled modules, so that 
the load module produced is relocatable-. It 
also allows the reordering and combining of 
named sections between modules and supports 
incremental linking. 


Operating Environment. Z8000 PLZlSYS is 
supported on Zilog's S8000 Development 
System. 
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FEATURES 
o 
Provides 
high-quality 
floating-point 
arithmetic 
capability for Z8000 series CPUs. 


o 
Executes the same instruction set and simulates the 
architecture of Zilog's Z8070 Arithmetic Processing 
Unit (APU). The same application software can use 
either this emulation package or the Z8070 APU 
without modification. 


GENERAL DESCRIPTION 


The Floating-Point Software Emulation Package (also 
referred to as the Emulator) provides floating-point 
arithmetic capability in accordance with the proposed 
IEEE Standard for binary floating-point arithmetic. 


The proposed standard is designed to facilitate the por- 
tability and increase the preCision and reliability of 
'numerically oriented programs. The Emulator's ability to 
handle various numeric formats makes it amenable to 
commercial as well as scientific applications. Because 
the Emulator simulates the Z8070 APU, it is an ideal tool 
for systems that may later include the Z8070 chip. 


The Emulator is written in PLZ/ASM structured assembly 


FUNCTIONAL DESCRIPTION 


The Emulator consists of a small system-dependent 
module involved with memory accesses, and a system- 
independent body. The 
system-dependent module 


comes in PLZ/ASM source form, whereas the body is in 
object code. Two versions of the body are provided: one 
assembled for segmented operation, the other for 
nonsegmented use. The Emulator ca-n, consequently, be 
run in either segmented or nonsegmented mode. The 
Emulator uses no privileged CPU operations, and most 
operations finish in under one millisecond on a 6 MHz 
CPU, including the trapping and typical operating system 
overhead. 


The system-independent body is called by the system- 
dependent module, using Zilog's calling convention. The 
system-independent body consists of approximately 
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o Conforms to the proposed IEEE Standard P754 Draft 


9.0 for binary floating-point arithmetic. 


o 
Provides routines for the conversion of binary in- 
teger and Binary Coded Decimal (BCD) to and from 
binary floating-point formats. 


language and is fully operable on the Z8000 series 
CPUs. 
It can 
be 
run 
in 
either segmented 
or 
nonsegmented modes and in either Normal or System 
modes. It is available with Zilog's Real-Time Software 
(ZRTS) and Zilog's System 8000. 


The Emulator uses the Z8000 CPU's Extended Process- 
ing Architecture (EPA). The EPA function provides the 
capability for flexible hardware and software expansion 
by the addition of Extended Processing Units or software 
trap handlers. When the EPA bit in the'CPU's Flag and 
Control Word is zero, the CPU traps to the Emulator upon 
encountering a floating-point instruction. 


5000 bytes of code and requires fewer than 30 words of 
stack space for operation. After an operation, the body 
returns a status code, indicating whether or not a trap 
should be taken. 


In the system-dependent module, the m6st important 
aspect of the Emulator is its method of acceSSing the ad- 
dress spaces of the process that generated the EPA 
trap. A small set of assembly language interface routines 
that can be tailored to the host system is provided in 
PLZ/ASM source form. These routines are fully general 
in that they permit trapped processes from either 
nonsegmented or segmented operating modes and from 
either System or Normal operating modes. Host systems 
not supporting some of these combinations can simpiy 
ignore them. 
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A user with an average mathematical background 
should be able to attain precise results with the floating- 
point arithmetic supported by the Emulator, because the 
software simplifies the development of accurate pro- 
grams. The Emulator accepts numbers in any of several 
data formats, operates on them in the very precise Ex- 
tended format, returns results to any of the formats, and 
indicates any exceptions that may arise. 


Exceptions, as defined by the proposed IEEE Standard, 
include detection of invalid operands or results, attemp- 
ted division by zero, and overflows or underflows caused 
by exceeding the limits of the data format. Exceptions 
can be handled by user-controlled traps, or can be dealt 


ARCHITECTURE 


There are eight 80-bit data registers, two 32-bit status 
registers, one 16-bit and one 32-bit control register, and 
two 80-bit floating operand registers in the Emulator. 
This software architecture is designed to simulate the 
Z8070 APU. 


The Emulator has a data register file of eight 80-bit 
registers labelled FO to F7. This format corresponds to 
the Double Extended format in which the Emulator per- 
forms all of its internal numeric operations. Figure 1 ill- 
ustrates the data register file. 


79 
78 
64 
63 


FR7 


FR6 


FRS 


FR4 


FR3 


FR2 


FR1 


FRO 


SIGN 
EXPONENT 
SIGNIFICAND 


Figure 1. Data Register File 


There are two 32-bit status registers known as the Pro- 
gram Counter register (PC1) and the Flags register. PC1 
(Figure 2) holds the address of the instruction that 
generated the trap. The Flags register contains historical 
information on detected exceptions (sticky flags) and the 
Emulator's Compare and Remainder flags (Figure 3). 


~ 
23 
15 


SEGMENT ~ 
OFFSET 


Figure 2. Program Counter Register (PC1) 
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with in an automatic manner by the Emulator. In addi- 
tion, the Emulator records historical information on ex- 
ceptions for later evaluation. This creates a flexible en- 
vironment in which the user can tailor exception hand- 
ling based on the needs of a specific application. 


The capabilities of the Emulator are of use wherever 
consistency of results, precision of results, manipulation 
of a wide range of numbers, or generally increased 
arithmetic processing capabilities are required. Such 
widely divergent applica:tions as guidance systems, 
financial data processing, process control, graphics and 
robotics can be enhanced by increased arithmetic 
capabilities. 


Flags Register. Four fields provide information on ex- 
ceptions and results: These fields are: 


Sticky flags. Eight flags are set when an exception oc- 
curs, and remain set until they are cleared by the pro- 
grammer. These flags are: 


INV-Invalid 
FOV-Floating-point Overflow 
U N-U nderflow 
DZ-Divide-by-Zero 
INX-Inexact Result 
DE-Denormalized number 
NAN-Signalling NaN 
IX-Integer Overflow 


Previous Operation flags. These are the same as the 
sticky flags, except these bits reflect the exception of the 
previous operation. 


Compare and Remainder flags. These status flags cor- 
respond to the H, D, PIV, S, Z, and C flags in the Z8000 
CPU's Few. 


FOP1E. These bits are the two most significant bits 
(MSB) of the exponent of Floating Operand register 1 
(FOP1). 


FOP2E. These bits are the two MSBs of the exponent of 
Floating Operand register 2,(FOP2). 


There are two control registers in the Emulator: the 
System Configuration register and the User Control 
register. The System Configuration register is accessible 
only to privileged users in System mode; it contains in- 
terrupt controls and EPU information (Figure 4). The 
User Control register (Figure 5) is accessible to Normal 
mode users; it sets arithmetic modes and enables traps. 
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System Configuration Register. Ten fields provide in- 
formation on instructions and interrupts. These fields 
are: 


User Control Register. Three fields enable traps and 
determine arithmetic modes. These fields are: 


Interrupt Vector Number. Identifies the source and 
cause of an interrupt. 


SV. Shifts the Interrupt Vector left. 


Rounding mode (RM). 
00 = Round to Nearest 
01 = Round toward Zero 
10 = Round toward Plus Infinity 
11 = Round toward Minus Infinity 
VIS. Is set to include status information in the Interrupt 
Vector. 
Trap Enables. The setting of these bits enables the trap 
associated with each exception Jisted below. 
NV. Is set when no vector is to be returned. 


IUS. Is set when an interrupt is under service. 


Interrupt Pending (lP). Indicates a pending interrupt. 


Master Interrupt Enable (MIE). Enables all interrupts. 


Used (U). Indicates that a floating-point instruction has 
been executed. 


INV-Invalid 
FOV-Floating Point Overflow 
UN-Underflow 
OZ-Oivide-by-Zero 
INX-Inexact Result 
OE-Oenormalized number 
NAN-Signalling NaN 
IX-Integer Overflow 


ID. Indicates the number in the 10 field of EPU instruc- 
tions to which the Emulator will respond. 


Invalid ID. Specifies which 10 fielci" in EPA instructions 
should cause a trap to be generated. 


In addition, the Emulator contains two 80-bit floating 
operand registers labelled FOP1 and FOP2, which con- 
tain the input operand (FOP1) and result (FOP2) for use 
by trap handlers (Figure 6). 
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Figure 3. Flags Register 


Figure 4. System Configuration Register 
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Figure 5. User Control Register 


FLOATING OPERAND 1 (INPUT OPERAND) 
I S I 
EXPONENT 


L-15 LEAST SIGNIFICANT BITS OF 


EXPONENT (2 MSB's IN FLAGS REGISTER) 


FLOATING OPERAND 2 (RESULT) 
I S I 
EXPONENT 


L-15 LEAST SIGNIFICANT BITS OF 


EXPONENT (2 MSB's IN FLAGS REGISTER) 


SIGNIFICAND 


SIGNIFICAND 


Figure 6. Floating Operand Registors 
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DATA TYPES 


The Emulator supports the data types shown in Figure 7. 
All formats are automatically cO!lVerted to the BO-bit 
floating-point format for internal operations and can be 
returned to any of the formats. The S bit is the Sign bit 
specifying a positive (0) or negative (1) number. The 
negative or positive floating-point numtler is equal to: 


The value (v) of the 32-bit Single Precision Binary format 
is determined as follows: , 


• 
If e = 255 and f =1= 0, then v = NaN. 


• 
If e = 255 and f = 0, then v = (-1 )S(infinity). 


• 
If 0 < e < 255, then v = (-1)S2e-127(1.f). 


significand X 2(exponent-bias) 
• 
If e = 0 andf =1= 0, then v = (-1)S2-126(0.f). 


• 
If e = 0 and f = 0, then v = (-1)SO,(zero). 
The Emulator also supports extensions to the floating- 
point arithmetic. Infinities are represented, and numbers 
that cannot be represented in normalized form (Le., 
where the most significant bit of the significand is a 
binary 1) can be represented in a denormalized form 
(Le., with leading Os in the significand). In addition, cer- 
tain values for NaNs (Not-a-Number) are defined, which 
are useful in causing traps or providing diagnostic infor- 
mation. 


The value of the 64-bit Double Precision Binary format is 
determined as follows: 
. 


• 
If e = 2047 and f =1= 0, then v = NaN. 


• 
If e = 2047 and f = 0, then v = (-1)S(infinity). 


• 
If 0 < e < 2047, then v = (-1)s2e-1023(1.f). 


In the following description of the binary floating-point 
formats, 's' is the sign, "e' is the exponent, 'f' is the 
significand (or fraction), and j is a 1-bit integer part. The 
integer biUs implicit in single and double formats. 


• 
If e = 0 and f =1= 0, then v = (-1)S2-1022(0.f). 
a 
If e = 0 and f = 0, then v = (-1)SO,(zero). 
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s = sign bit 
e = exponent lIeld 
f = fraction lIeld 
I = Integer bit 


Double Precision Binary (64 bits) 


64 63 62 


Extended Precision Binary (80 bits) 


UP TO 19 BCD DIGITS 


Binary Coded Decimal Integer 


Binary Integer (32 and 64 bit two's complement Integers) 


Figure 7. Data Formats 
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For the 80-bit Double Extended Precision Binary format, 
the value is determined as follows: 


1:1 
If e = 32767 and f * 0, then v = NaN. 


II If e = 32767 and f = 0, then v = (-1)8(infinity). 


• 
If 0 < e < 32767, then v = (-1)82(e-16383)U.f). 


II If e = 0 and j = f = 0, then v = (-1)80, (normal 


zero). 


• 
If e = 0 and j or f is nonzero, then v = 
(-1 )52-16383U. f). 


Floating-point instructions are of the form: 


FXXX [S,D,L,Q,BCD] rnd dst,src 


The suffixes for floating-point binary formats [Single (S), 


INSTRUCTION SET 


The floating-point instruction set provides the following 
types of instructions: 


.. Primary arithmetic operations 


• 
Load and store operations 


.. Compare and examine operations 


Primary Arithmetic Operations 


Double (D), or Extended (no suffix)], for binary integer 
formats [Long-word (L) and Quad-word (Q)], and for 
decimal format (BCD), refer to the size of the CPU 
register or memory operand. The suffix "rnd" refers to 
the rounding precision, or the degree of precision used 
in internal.Emulator operations; SGL is used for Single 
precision, DBL for Double precision, and no suffix for Ex- 
tended precision. 


Addressing modes used include Emulator register (F) 
and multiple register (FF), CPU register (R), Index (X), In- 
direct Register (lR), Direct Address (DA). Also permitted 
are addressing of Emulator Control registers (FCTL) and 
portions of the Control registers (FSEL, traplist, flag list, 
modelist). 


• 
Secondary arithmetic operations 


• 
Control operations 


Mnemonic 
Operands 
Addressing Modes 
Operation 


FADD 
FADDS 
FAOOO 


FOIV 
FOIVS 
FOIVO 


FMUL 
FMULS 
FMULO 


FREMSTEP 


FSQR 
FSQRS 
FSQRO 


FSUB 
FSUBS 
FSUBO 


FLO 
FLOS 
FLOO 


dst,src 


dst,src 


dst,src 


dst,src 


dst,src 


dst,src 


dst,src 


src: F,R,IR,DA,X 


dst: F 


src: F,R,IR,DA,X 


dst: F 


src: F,R,IR,DA,X 


dst: F 


src: F 
dst: F 


src: F,R,IR,DA,X 


dst: F 


src: F,R,IR,DA;X 


dst: F 


src: F,R,IR,DA,X 
dst: F 
or 
src: F 
dst: R,IR,DA,X 


Floating Add 


dst - 
dst + src 


Floating Divide 


dst - 
dst/src 


Floating Multiply 


dst - 
dst* s rc 


Floating Remainder Step 


dst - 
dst src 
FCW - 
flag 


Floating Square Root 


dst - 
SQR (src) 


Floating Subtract 


dst - 
dst - 
src 


Floating Load 


dst - 
src 
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Load and Store Operations 


Mnemonic 
Operands 
Addressing Modes 
Operation 


FLO BCD 
dst,src 
dst: F 
Floating Load BCD Integer 


src: R,IR,DA,X 


or 
dst - 
Float (BCD_src) 
dst: R,IR,DA,X 
dst - 
BCD (floaLsrc) 


src: F 


FLDIL 
dst,src 
dst: F 
Floating Load Binary Integer 
Long Word 
src: RR,IR,DA,X 


or 
dst - 
Float (src) 
dst: RR,IR,DA,X 
dst - 
Fix (src) 
src: F 


FLDIQ 
dst,src 
dst: F 
Floating Load Binary In.teger 
Quad Word 
src: RQ,IR,DA,X 


or 
dst - 
Float (src) 
dst: RQ,IR,DA,X 
dst - 
Fix (src) 
src: F 


FLDM 
dst,src,n 
dst: F,FF 
Floating Load Multiply 
src: R,IR,DA,X 


or 
dst - 
src 
dst: R,IR,DA,X 
src: F,FF 


FLDTL 
dst,src 
dst: RR,IR,DA,X 
Floating Load and Truncate to 
Integer Long Word 


src: F 
dst - 
Int (src) 


FLDTQ 
dst,src 
dst: RQ,IR,DA,X 
Floating Load and Truncate to 
src: F 
Integer Quad Word 


dst - 
Int (src) 


. Compare Operations 


FCP 
dst,src 
dst: F 
Floating Compare 
FCPS 
FCPD 
src: F,R,IR,DA,X 
dst - 
src, set flags 


FCPF 
dst,src 
dst: F 
Floating Compare and Transfer 
Flags to FCW 


src: F 
dst - 'src 
FCW - 
flags 


FCPFX 
dst,src 
dst: F 
Floating Compare, Transfer Flags to 
FCW, and Raise Exception if 


src: F 
Unordered 


dst - 
src 


FCW.- flags 


FCPX 
dst;src 
dst: F 
Floating Compare and Raise 
FCPXS 
Exception if Unordered 
FCPXD 
src: F,R,IR,DA,X 


dst - 
src, set flags 
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Compare Operations (Continued) 


Mnemonic 
Operands 
Addressing Modes 
Operation 


FCPZ 
dst 
dst: F 
Floating Compare with 0, and 
Transfer Flags to FCW 


dst - 
0 


FCW - 
flags 


FCPZX 
dst 
dst: F 
Floating Compare with 0, Transfer 
Flags to FCW, and Raise Exception 
if Unordered 


dst - 
0 


FCW - 
flags 


Secondary Arithmetic Operations 
N co 
0 
FABS 
dst,src 
dst: F 
Floating Absolute Value 
~ = 
FABSS 
IIJ 
FABSD 
src: F,R,IR,DA,X 
dst - 
Isrcl 
- 
0 
DJ - 
FCLR 
dst 
dst: F 
Floating Clear 
- 
1:1 


dst - 
+0 
cQ • 
0 


FINT 
dst,src 
dst: F 
Floating Round to Floating Integer 
- 
! 
FINTS 
m 
FINTD 
src: F,R,IR,DA,X 
dst - 
Float [Int (src)] 
- 
~ 
~~ 


FNEG ~"" . 
dst,src 
dst: F 
Floating Negation 


FNEGS 
FNEGD 
src: F,R,IR,DA,X 
dst - 
(-src) 


Control Operations 


FLDCTL 
dst,src 
dst: FCTL 
Floating Load Control 
src: RR,IR,DA,X 


or 
dst - 
src 


dst: RR,IR,DA,X 
src: FCTL 


FLDCTLB 
dst 
dst: Fsel 
Floating Load Control Byte 


FCW - 
flags 


FRESFLG 
src 
dst: FFLAGS 
Floating Reset Flag 


src: flaglist 
FFLAGS (flaglist) - 
0 


FRESTRAP 
src 
dst: USER 
Floating Reset Trap 
src: traplist 
USER (traplist) - 
0 


FSETFLG 
src 
dst: FFLAGS 
Floating Set Flag 


src: flaglist 
FFLAGS (flaglist) - 
1 


FSETMODE 
src 
dst: FMODE 
Floating Set Mode 
src: modelist 
FMODE - 
modelist 


FSETTRAP 
src 
dst: USER 
Floating Set Trap 
src: traplist 
USER (traplist) - 
1 
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Condition Codes 


A set of condition code mnemonics are provided ·for 
evaluating the results of floating-point comparisons 
when the results have been transferred to the CPU's 
Flag and Control Word. Table 1 shows the floating-point 
mnemonics, the equivalent Z8000 condition code 
mnemonics, and their meanings. 


Programming Example 


An example of a FORTRAN program and 'its possible 
compilation is provided below. The example calculates 
an 
average, 
using 
floating-point 
instructions and 
Emulator registers as well as CPU instructions and 
resources. 


The FORTRAN segment assumes type REAL is a single 
precision number. The possible compilation of the FOR- 
TRAN segment assumes that the compiler optimizes 
variable usage in DO loops-it does not emulate full 
FORTRAN DO loop conditions. PLZ/ASM is the code pro- 
duced. 


FORTRAN Program Segment 


100 
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REAL SAMPLE(100),AVERAGE 
INTEGER INDEX 
• 
• • 


AVERAGE = 0.0 
DO 100 INDEX = 1,100 
AVERAGE = AVERAGE + SAMPLE(INDEX) 
AVERAGE = AVERAGE/100.0 


Table 1. Cond.ltlon Code Equivalences 


Floating' 
. point CC 
Z8000 CC 
Meaning 


FEO 
EO 
FNEU 
NE 
FLT 
ULT 
FLE 
ULE 
FGT 
GT 
FGE 
GE 
FLU 
LT 
FLEU 
LE 
FGU 
UGT 
FGEU 
UGE 


FORD 
NOV 


FUN 
OV 


Equal 
Not equal or unordered 
Less than 
Less than or equal 
Greater than 
Greater than or equal 
Less than or unordered 
Less, equal or unordered 
Greater than or unordered 
Greater, equal or unordered 
Ordered 
Unordered 


Possible Assembler Compilation 


SAMPLE ARRAY [100 LONG] 
AVERAGE LONG 
K100 
LONG = 100.0 
• • 
• 


FCLR 
CLR 


LOOP 
FADDS 
INC 
CP 
JR 
FDIVS 
FLDS 


!REGISTER ASSIGNMENTS! 
!INDEX - R2! 
!AVERAGE - FO! 
FO 
R2 
FO,SAMPLE(R2) 
R2,#4 
R2,#400 
LT,LOOP 
FO,K100 
AVERAGE,FO 


00-2283-02 


Zilog 


II Real-time Multi-Tasking Software 
Components 


o Synchronization of multiple tasks 


• Interrupt-driven priority schedul- 


ing 


• Real-time response 


• Dynamic memory allocation 


• Modular and Flexible Design 


• Efficient memory utilization 


• 6K byte PROMable kern~l 


Q Support for 28001 and 28002 


16-bit microprocessors 


• Configurable via linkable 
modules 


iii Versatile Base for Z8000™ System 


Designs 


• Segmented/non-segmented tasks 


• System/normal mode tasks 


• Uses standard Zilog calling con- 


ventions 
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Preliminary 


September 1983 


[J Easy-To-Use System Generator 


o High-level configuration 
language 


o Supports a wide variety of hard- 
ware configurations 


o Easily changed control 
parameters allow system 
optimization 


. 0 Eliminates the requirement for 
intimate knowledge of system in- 
ternal structure 


OVERVIEW 


Zilog's Real Time Software (ZRTS) 


provides of a set of 'modular software 
components that allows quick and easy 
implementation of customized 
operating systems for all members of 
the 28000 16-bit microprocessor family. 
In effect, ZRTS extends the instruction 
set of the Z8000, adding easy-to-use 
commands that give the Z8000 the 
capability for managing real-time, 
multi-tasking applications. 


The ZRTS package consists of a 
small real-time, multi-tasking executive 
program, the Kernel, and a System. 
Configurator. The Kernel prOVides 
sychronization and control of multiple 
events occurring in a real-time en- 
vironment. All major real-time func- 
tions are available-task synchroniza- 
tion, interru'pt-driven priority sdhedul- 
ing, intertask communication, real-time 
response, and dynamic memory alloca- 
tion. The System Configura tor is a 
language processor that allows the 
target operating system to be defined 
in high-level terms using the ZRTS 
Configuration Language (ZCL). 


These functions greatly simplify the 
tasks of the designer, allowing 
development efforts to be concentrated 
on the application, instead of on real- 
time coordination, task management 
problems, and complicated system 
generations. ZRTS provides a modular 
and flexible development tool that 
serves as a versatile base for 28000 
system designs. The Kernel requires 
only 6K bytes of either PROM or RAM 
memory, thus allOWing configurations 
for a wide variety of target systems, 
while producing a memory-efficient. 
cost-effective end product 


839 


CONCEPTS 


ZRTS is both easy-to-Iearn and easy- 


to-use. Oniy a few simple concepts 
need to be understood before design- 
ing begins. 


Tasks. Tasks are the components com- 
prising a real-time application. Each 
task is an independent program that 
shares the processor with the other 
tasks in the system. Tasks provide a 
mechanism that allows a complicated 
application to be subdivided into 
several independent, understandable, 
and manageable units. 


Semaphores. Semaphores provide a 
low overhead facility for allowing O1)e 
task to signal another. Semaphores can 
be used for indicating the availability 
of a shared resource, timing pulses or 
event notification. 


Exchanges and Messages. Exchanges 
and Messages provide the mechanism 
for one task to send data to another. A 
Message is a buffer of data, while an 
Exchange serves as a mailbox at which 
tasks can wait for Messages and to 
which Messages are sent and held. 
Two components make up the heart 
of ZRTS-the ZRTS Kernel and the 
ZRTS Configuration Language (ZCL). 
An va subsystem and a debugger are 
also provided in ZRTS. 
The ZRTS Kernel. The Kernel is the 
basic building block of ZRTS and per- 
forms the management functions for 
tasks, semaphores, the real-time clock, 
memory and interrupts. The Kernel 
also provides for task-to-task com- 
munications via Exchanges and 
Messages. All requests for Kernel 
operations are made via system call 
instructions with parameters' in 
registers, according to the standard 
Zilog calling conventions. 


Task Management. One of the main 
activities of the Kernel is to arbitrate 
the competition that results when 
several tasks each want to use the pro- 
cessor. Each task has a unique task 
descriptor that is managed by the 
Kernel. The data contained in the 
descriptor includes priority, status and 
other pertinent information. ZRTS sup- 
ports any number of tasks, limited only 
by the memory available to accom- 
modate the task descriptors and stacks. 
The Kernel maintains a queue of all 
active tasks on the system. Each .laskis 
scheduled for processor time based on 
its priority. The highest-priority task 
that's ready to run gains control of the 
CPU; other tasks are queued. Tasks 
can be prioritized up to 32767 levels, 
with round-robin scheduling among 
tasks with the same priority. 
Tasks can run either segmented or 
non-segmented code, in either normal 
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'TASK MANAGEMENT 


T_Create 


T_Destroy 


T_Lock 


T_Reschedule 


T_Resume 


T_Suspend 


T_Unlock 


T_Wait 


T_Whoami 


SEMAPHORE MANAGEMENT 


Se11'L-.Clear 


Se11'L-.Create 


Se11'L-.Destroy 


Se11'L-.Signal 


CLOCK MANAGEMENT 


Clk_Delay _Absolu te 


CILSet 


Clk_Time 


MEMORY MANAGEMENT 


Me11'L-.Census 


Alloc 


Release 


INTER-TASK COMMUNICATION 


~Assign 


M_Create 


M_Destroy 


M_GeLDescriptor 


~Read 


M_Receive 


~Receive_ Wait 


~Reply 


~Send 


~Write 
LCreate 


LDestroy 


.TABLE I. 


Provides the status of tasks in the 
system. 


Creates a task dynamically. 


Removes a dynamically created task. 


Allows a task to take exclusive control 
of the-CPU. 


Changes the priority of a task. 


Activates a suspended task. 


Suspends another task. 


Releases exclusive control of the CPU 
for other tasks. 


Suspends task execution. 


Returns the name (address) of the task 
making the request. 


Clears semaphore queue and 
reinitializes a semaphore. 


Creates a semaphore dynamically. 


Removes a dynamically created 
semaphore. 


Signals a s,emaphore, increments the 
counter. 


Tests a semaphore for a signal. 


Causes a task to wait until a semaphore 
is signaled, decrements the counter. 


Places a task on the clock queue 
waiting for absolute time. 


Places a task on the clock queue 
waiting for passage of an interval of 
time. 


Sets the 'real-time clock. 


Reads the clock. 


PrOVides status of the memory 
resource. 


Dynamically allocates memory. 


Releases allocated memory. 


Gets a messa.ge from an exchange pool 
and assigns a destination or a reply 
exchange to it. 


Assigns a new source and destination 
to an existing message. 


Creates a message dynamically. 


Removes a dynamically created 
message. 


Gets message's descriptor informfltion 


Reads the message data. 


Receives a message from an exchange. 


Waits to receive a message from an 
exchange. 


Returns a message to the exchange 
pool. 


Sends a message back to destination 
exchange. 


Sends a message to an exchange. 


Changes message data. 


Dynamically creates an exchange with 
a pool of messages. 


Removes a dynamically created 
exchange. 


or system mode. The numerous opera- 
tions that may be performed on tasks 
are listed in Table l. 


Semaphore Management. The Kernel 
provides semaphore management for 
synchronizing interacting tasks. A 
typical use of semaphores is to provide 
mutual exclusion of a shared resource. 
When a resource is to be used by only 
one task at a time, a semaphore with a 
counter of 1 controls the resource. 
Every task requiring the resource must 
first wait on that semaphore. Since the 
counter is I, only one task will acquire 
the resource. The others will be 
queued on the semaphore and 
suspended until the semaphore is 
signaled that the resource is once 
again available. At that time, the first 
task on the semaphore queue will be 
made ready to run and can use the 
resource. After all tasks have ,?cquired 
the resource and signaled the comple- 
tion of their use, the semaphore returns 
to its original state with a counter of 1. 
Counters greater than one are useful 
when there are a number of similar 
resources, (Le., three tape drives, four 
I/O buffers, etc.). 
In ZRTS, a semaphore can count up 
to 32767 signals. The commands pro- 
vided by the Kernel to manage 
semaphores are listed in Table l. 


Clock Management. ZRTS operates 
with a real-time clock that generates 
interrupts at a hardware-dependent 
rate. It is use? for timed waits, 
timeouts, and round-robin scheduling. 
All times are given in number of ticks. 
The clock may be manipulated by the 
set of commands provided by the 
Kernel that are listed in Table l. 


Memory Management. Storage for 
ZRTS data structures is allocated either 
statically at system generation time, or 
dynamically at run time. Dynamic 
allocation occurs via a system call that 
specifies the attributes of the structure 
to be created and returns a name that 
can be used to refer to the structure. 
Memory is allocated in 256-byte 
increments, and can be released using 
a system call. 
The storage allocator can also be 
called directly to obtain blocks of 
memory up to 64K bytes long, which 
can be used by the task for any 
purpose. 


Interrupt Management. Interrupt- 
handling routines are provided for 
system calls, non-vectored interrupts 
and a hardware clock. The user must 
provide interrupt routines for whatever 
other vectored interrupts are included 
in the target system. 


ZRTS can switch control to a task 
waiting for an external event within 
600-microseconds after the occurrence 


TABLE 2. 


CONSTANTS 


EXCHANGES 


INiTIALIZATION 


INTERRUPT 


MEMORY 


SEMAPHORES 


SWITCHES 


TASKS 


of the event. This is a worst-case time 
for a system using a 4 MHz Z8001 CPU 
and is based on a SeID-Signal system 
call awakening a higher priority task 
that is waiting on a semaphore; this 
causes a task switch to occur. 


Inter-Task Communication. The 
Kernel provides the capability for tasks 
to exchange information. This com- 
munication process occurs when one 
task sends a Message to an Exchange 
and another task receives the Message. 
A Message contains a length indi- 


cator, a buffer with a variable amount 
of data, and a code that identifies the 
Message type. The Exchange is a 
system data structure that consists of a 
queue for Messages sent but not yet 
received, a semaphore on which a task 
can wait for a Message, and an 
optional "pool" list from which 
Messages can be obtained quickly. 


SYSTEM 
·l----.... CONFIGURATION 


Specifies system constants. 


Defines the characteristics of applica- 
tion exchanges. 


Specifies routines that are to execute 
prior to beginning execution of the first 
task. 


Associates an interrupt routine with an 
interrupt vector or trap and system 
call-handlers. Provides the facilities to 
specify a NVI interrupt-handler that 
will be called from the system NVI- 
handler routine. 


Defines sections or segments that con- 
tain code, initialized data, or 
uninitialized data and speCifies the 
location in memory where it will be 
placed. The files to be included in the 
configuratfon are also defined in this 
section in conjunction with the sec- 
tion/segment definitions. 


Defines the characteristics of applica- 
tion semaphores. 


Allows flags that control the system 
generation operation to be set. 


Defines the characteristics of applica- 
tion tasks. 


ZRTS provides several commands for 
inter-task communications. These are 
listed in Table l. 


Logical 1/0. ZRTS includes an op- 
tionalmodule which provides a device- 
independent mechanism for interfacing 
between tasks and customer-written I/O 
device drivers. Sample device drivers 
are included for terminal and disk-type 
devices. 


ZRTS Configuration Language (ZCL). 
Since ZRTS's modular design leads to 
so many different configurations, a 
simple facility for generating the target 
operating system is a critical part of 
the ZRTS package. The ZRTS Con- 
figuration Language (ZCL) provides an 
easy-to-use means for generating the 
target system. Using ZCL, the designer 
can specify hardware information, soft- 
ware parameters, linkage information, 
and system data structures in high- 
level terms. 


USER 
APPLICATION 


zaooo 
DEVELOPMENT 
GULE 


Development Environment 
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ZCL unburdens the user of the 
necessity to learn the details of the 
ZRTS internal structures. System data 
structures can be generated simply by 
specifying the appropriate parameters. 
The ZCL syntax is free-format with 
comments allowed to make the con- 
figuration commands more readable 
and maintainable. 


ZCL input is comprised of a number 
of descriptive sections, each containing 
the details of the target operating 
system. The functions of these sections 
are described in Table 2. A sample 
system generation using ZCL is il- 
lustrated in Figure l. 
DEVELOPMENT ENVIRONMENT. 
Application modules for ZRTS are 
developed on a Zilog System 8000. The 
application or system generated can 
then be downloaded into a Zilog S8000 
Development Module or a customized 
target system. 
An interface package is provided for 
making ZRTS system calls from pro- 
grams written in C, Pascal, or FOR- 
TRAN. Register usage by the system 
calls is compatible with Zilog's calling 
conventions. 
A debugger is provided with ZRTS 


for use in testing and debugging ap- 
plications. After the application is 
debugged, the system can be easily 
reconfigured (without the debugger) 
into its final form. 


ORDERING INFORMATION 


Description 


ZRTS Zilog Real-Time Software for the Z8000 
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lJ High-Lovol Procoduro-Oriented 
Languago Permits Efficiont 
Writing of Machine-Independent 
Modules and Programs. 


[J Structured Format for Fast and 
Easy-to-Compilo Programs. 


[J Prod\1ces Efficient Codo for 
Economical Momory Usago and 
Processing Timo. 


[J Simplifies Softwaro Production 
and Maintenance. 


[J Allows Direct or Interprotivo 
Execution of Program Modules. 


FEATURES 


Compiler. The 280 PLZlSYS Compiler 
translates source code modules into an 
intermediate stage called Z-code. The 
Z-code modules may then be executed 
interpretively or processed by the code 
generator to produce a machine-code 
object module. 


Codo Gonerator. The 280 PLZCG 
Code Generator accepts a file of inter- 
mediate Z-code generated by PLZlSYS 
and produces the corresponding 280 
machine code as a relocatable object 
module. This file may be linked with 
other modules to form the complete ex- 
ecutable load module. 


Intorprotor. The intermediate Z-code 
modules produced by the Z80 PLZlSYS 
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Z80 PLZ 
Object Diskette for use 
with PDS 8000105 and 
PDS 8000/15 
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OVERVIEW 


Z80 PLZ is a family of different pro- 
gramming languages designed to 
. satisfy a wide range of microcomputer 
software development requirements. 
The two members of the PLZ family, 
PLZlSYS and PLZI ASM, produce object 
code-compatible modules and share 
common control structures and data 
definition facilities. Thus, selective por- 


, tions of programs may be written in the 
most appropriate language for the 
specific application and still maintain a 
consistent structure between modules. 


Compiler can be executed interpre- 
tively by ZINTERP. Linking ZINTERF> 
with the other modules generated by 
the compiler produces an executable 
load module. 


PLZ/ ASM Translator. The PLZ FILTER 
translates a PLZI ASM source module 
into a file of the corresponding Z80 
Assembler source. This gives the . 
Assembler the benefit of logical data 
structure, program flow control, and 
modular program design, in addition to 
its existing features. 


PLZ Linl:er. The PLZ Linker, PLINK, 
links Z-code, ZINTERP and/or machine 
code modules into a single relocatable 
load module, allowing the user to con- 
trol the overall size and speed of the 
program. 


07-3302-01 
Z80 PLZ 
Object Diskette for use 
with ZDS-l Series 


PLZlSYS is a high-level, procedure- 
oriented language that is syntactically 
similar to PASCAL. It provides a 
medium for writing structured, 
machine-independent programs with a 
minimum of programming effort. 


PLZI ASM, on the other hand, is a 
structured assembly language that per- 
'±nits access to the low-level capabilities 
of the processor by mixing assembly 
language and high-level control 
structures. 


Although interpretive Z-code runs 
more slowly than machine code, the 
, space savings over machine code is 
usually substantial for larger programs 
'where the 3K bytes of ZINTERP is a 


~mall percentage of the entire pro- 
gram. By balanCing the number of 
Z-code and machine code modules, the 
user can maximize the efficiency of a 
particular program. 


PLINK resolves any external refer- 
ences between separately assembled 
modules, so that the load module pro- 
duced is relocatable. It also allows the 
reordering and combining of named 


section~ between modules and supports 
incremental linking. 


07-3303-01 
Z80 PLZ 
Object Cartridge Disk 
for use with PDS 8000/20 
and PDS 8000/30 
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Figure 1. Z8D PLZ Language Modules. 
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OVERVIEW 


The Z800 Cross-Software Package is a complete 
development environment that provides all the tools 
necessary to both generate and debug programs for the 
Z800 MPU. The package-a comprehensive collection 
of software routines and utilities-allows programmers 
to prepare, modify, test, and debug their software prior 
to release of the Z800 chip. The result of this com- 
prehensive software testing and evaluation is a high- 
quality design that will be ready for end use by the time 
the hardware has been perfected. 


The user interface for each of the program. tools is 
similar to the standard UN IX* interface. Code testing 
and debugging can be done either with the Instruction 


~800!M 
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lProdl unci 
.DescripftnoBU 


September 1983 


Level Simulator (ILS) on the host system or'by download- 
ing to a Z800-based target system; mload and msend 
utilities are included to manage the host-to-target 
system communication. Use of the ILS facility allows 
program ~ebugging well in advance of prototype hard- 
ware availability. 


All the software tools in the Cross-Software Package are 
designed to run on either the DEC-VAX or the Zilog ZEUS 
S8000, both with a UNIX operating system. The program- 
mer can choose either the C programming language or 
Z800 (Z80-compatible) assembly language to develop, 
load, test, debug and run programs for the Z800 MPU. 


DEVELOPMEtn 
BOARD 


Z800 Cross-Software Package 


·UNIX is a trademark of Bell Laboratories. 


2311-001 
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FEATURES 


The l800 Cross-Software Package consists of the 
followif")g tools: 


• 
C Cross Compiler. Produces efficient assembly- 
language code. Standard run-time library included. 


• 
Cross Assembler. Relocatable assembler with 
macros, conditional assembly, and floating-point 
support. 
. 


• 
Linker. Handles full address range of the l800 
MPU using proposed IEEE-standard MUFOM format. 


• 
Instruction Level Simulator. Debugging environ- 
ment for l800 code on cross-software host. 


DESCRIPTION 


C Cross Compiler 


\ 
The l800 C Cross Compiler is a UNIX-license-free C 
compiler, designed to run on either lilog's UNIX S8000 
or the DEC-VAX. The l800 Compiler includes a Bell 
System V-compatible front end, and a back end 
generated by an automatic code-generator. Running at 
speeds similar to the Portable C Compiler, the l800 
Compiler features a variety of optimizations, some 
machine-independent, others machine-dependent. 


The compiler supports the latest version of the C pro-. 
gramming language, and thus includes longword and 
floating-point support, enumerations, structure assign- 
ment, and full "define" capability. The compiler can 
automatically invoke the C optimizer to produce more ef- 
ficient code. The compiler produces assembly language 


• 
Object File Utilities. Standard UNIX object utilities 
for MUFOM files, plus upload/download to target. 


• 
Portable Debugger. Written in C language, the 
debugger facilitates the use of different hosts. It not 
only runs on l800 target systems, but is also the 
user interface to the ILS. 


II Test cases. Included with each tool for product 
testing. 


II 
Documentation for each tool in the package. 


code as output to allow easy debugging of the compiled 
code, or to allow hand optimization for critical code sec- 
tions. A listing file can be generated that shows the 
assembly language interspersed with ,the C code that 
produced it. 


Options include: 


I!!J 
0 invokes the C optimizer. 


E1 
s compiles the source files but suppresses the 
assembly and link steps. 


GJ 
c compiles and assembles the source files but sup- 
presses linking. 


Without the use of these options, the C Cross Compiler 
by default compiles, assembles, and links l800 code. 
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,Typical Z800 Cross-Software Package Installation 
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Cross Assembler 


The Z800 Cross Assembler utilizes expanded Z80 
mnemonics and addressing modes to assemble and 
generate MUFOM object modules (IEEE proposed stan- 
dard #P695). The Z800 Cross Assembler is both 
fast-assembling at least 1,000 lines per minute-and 
efficient-consuming no more than 64K bytes of 
code/data space., Written in theC programming 
language, the assembler is designed to be easily 
retargetted. Additional features include macros, condi~ 
tiona I assembly, and relocation. The Z800 assembler is 
upwardly compatible with Zilog's Z80 gssembler and 
Microsoft's Macro-80 assembler. 


The assembler supports a full set of pseudo-ops in- 
cluding conditional pseudo-ops and a powerful macro 
capability as well as pseudo-ops to support floating-point 


opera~ions. A cross-reference listing can be generated 
to show the use and definition of all the symbols in the 
program. 


The assembler supports the complete list of opcodes in 
the Z800 MPU Preliminary Product Specification (docu- 
ment # 00-2259-01), plus the instruction set of the Z8070 
Floating-Point Unit. All Z80 opcodes,pseudo-ops, and 
commands supported by the Z80-RIO assembler are 
also supported. Constants supported by the assembler 
include integers, floating-point numbers, characters, and 
character strings. In addition, the assembler supports 
expressions using up to 80 bits of precision. 


Addressing modes for the assembler are also derived 
from the Z80 assembler: 


• 
Registar 


• 
Immediate 


III ' Indirect Register 


II Direct Address 


.. Indexed 


II Short Index 


• 
Based Indexed 


• 
Stack Relative 


IJ 
PC Relative 


Three kinds of macros are included in the Z800 
assembler: 


MACROs are compatible with the Z80 assembler. 
Parameters are separated by blanks or commas and are 
substituted into the macro body as strings. 


PROCs are call-by-value macros. Parameters are ex- 
preSSions, separated by blanks or, commas, and are 
substituted into the macro body as values. 


FUNCs are function macros. They are similar to PROC 
macros, except that they are recognized within expres- 
sions as operators or op.erands. 


Additional pseudo-ops are provided to extend macros, 
conditional assembly, data definition, and object code 
generation. A command-line option specifies a third pass, 
for generating a cross reference. 


Linker 


The Z800 linker is a processor-independent linker that 
combines MUFOM format-relocatable object modules 
generated by the cross assembler and resolves external 
refer..ences from within the modules or by searching ob- 
ject code libraries. The result is an executable, program 
that can be sent to a target syptem for execution or 
simulated on the ILS. The linker also provides many ad- 
vanced features such as complex expression evaluation 
with up to 80 bits of precision, multiple program/data 
segments of any length, and memory protection at- 
tributes for any portion of the memory space. ' 


Object File Utilities 


Z800 Cross Software Package includes a number of 
machine-independent utilities' for processing object 
modules created in MUFOM format. Because these 
utilities can be used for different computef systems 
without modification, the programmer is freed from such 
constraints as variations in address and data size; these 
potential snags are resolved by the MUFOM utilities 
themselves. 


MUFOM allows for up to 256 independently relocatable 
sections per module. This gives the programmer flexibil- 
ity and control over how the program is mapped in 
memory. Program size is approximately 96K bytes, with 
64K bytes for code and 32K for data. 


Object modules can be stored in either ASCII or binary 
format. While ASCII is useful fO[ downloading across 
serial links, binary modules require less file space and 
allow faster processing. 
' 


For linking and loading object modules, two utilities are 
provided:mlink and mload. mlink resolves external 
references among modules, relocates addresses, and 
combines the object modules into a single module called 
a load module. mload downloads an object file from the 
host system to the target system. mload and mlink can 
send or receive object files in either Tektronix hex for- , 
mat, Intel hex format, or ASCII MUFOM format. 


In addition to mlink and mload, there are several other 
functions performed by the MUFOM utilities: mnm, 
msend, mdump, mcb, and mbc. These facilities allow in- 
spection of object code files and the creation and 
maintenance of object libraries for use by the linker. 


mnm 
prints the name list (symbol table) of an object 
module. 


m'send 
uploads the contents of memory from a target 
system and creates an absolute MUFOM ob- 
ject module on the host system. 
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mdump 
dumps a hex object file along with relocation 
information; object header information is also 
displayed. 


mcb 
converts an ASCII object module into a binary 
module. 


mbc 
converts a binary object module into ASCII. 


Portable Debugger 


The l800 Portable Debugger is a versatile debugging 
system, able to run on either l800 (8-bit) or l8000 
(16-bit) microprocessor systems. The debugger is writ- 
ten in C language, using the standard C library as well as 
a library for stand-alone I/O and memory utilities ap- 
propriate to the target system. To facilitate the use of dif- 
ferent hosts (e.g., other UNIX systems, other operating 
systems such as CP/M, or development module en- 
vironments), the processor descriptor parameters, such 
as state structure/display, memory and I/O access, Mini 
Assembly and. Disassembly library routines (MAD) and 
the ILS, are contained in separate, easily modified 
modules. 


Instruction Level Simulator (ILS) 


The Z800 ILS is a powerful software tool that simulates 
execution of l800 instructions. These instructions can 
then be displayed and manipulated by the portable 
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debugger. The ILS facility executes l800 instructions at 
slower than real-time rates and allows access to the 
simulated processor registers and to the full range of 
simulated memory. The ILS supports both symbolic and 
mnemonic l800 opcode assembly, disassembly, and 
emulation. Additional features of the ILS include simula- 
tion of the on-chip MMU to provide a large (24M byte) ad- 
dressing space; multiple breakpoints; single-stepping; 
I/O simulation; full memory, register and flag access; 
and friendly error ~eporting. 


The ILS software, program accepts as input l800 
machine code generated by the l800 assembler; it then 
simulates changes in processor state. Each simulation is . 
a single-step routine that works in conjunction with the 
debugger. 


A typical process for using the ILS to generate, ~assem­ 
ble, and debug l800 software is as follows: 


1. A conventional editor is used to create a l800 


assembly language source file. 


2. The source file is then assembled and tested for syn- 


tax errors. 


3. The default MUFOM object file produced by the 
assembler, named m.out, is then loaded into the 
debugger/l LS and run. 
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Zilog 


II Structured Assembly Language 
with High-Level Constructs. 


• Relocatable and Absolute Object 
Code Format. 


iii Free Format Statements Allow 
Indentation and Spacing for 
Readability. 


m External Symbol References. 


II Global Symbol Definitions. 


OVERVIEW 


The Z8 Software Development 


Package consists of five utility pro- 
grams which aid and simplify software 
development for Z8-based systems. Z8 
PLY ASM, par1' of Zilog's PLZ family, 
brings all the advantages of modular 
programming to Z8 software develop- 
"ment: The programming task can be 
broken into easily managed modules, 
giving more work assignment options to 
the engineering manager and a clear- 
cut structure to the individual program- 
mer. The Z8 linker completes the task 
by combining the modules and resolv- 
ing any external references. 


ORDERING INFORMATION 
Prerequisites: 
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PDS 8000,Series 
ZDS 1146 or 1125 


MCZ~l Series 
RIO 


Z8® Software 
BDe'Ue!opmenl !iackage 


Product 
Description 
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FEATURES 


Assembler. The Z8 PLY ASM 
Assembler translates easy-to-read, free- 
format PLY ASM source programs to 
object code. Because the user may 
specify that either absolute or 
relocatable object code be produced, 
he may choose a memory location for 
the program or leave that responsibility 
to the Linker. The Z8 PLY ASM 
Assembler produces a listing file con- 
taining both the source and assembled 
code. 
Z8 PLY ASM allows an efficient mix 
of powerful assembly language 
mnemonics with high-level control 
structures such as IF . . . THEN . . . 
ELSE ... FI and DO ... aD loops. 
The PLY ASM programmer may map 
instructions and information into the 
Z8's register, program and data 
memory spaces, and organize the data 
space with such data declarations as 
RECORDS and ARRAYS. The 
PLY ASM Assembler supports external 
symbol references and global symbol 
definitions and is fully supported by 
. the RIOTM operating system. 


ZLINK. ZLINK links assembled modules 
into a single relocatable module and 
resolves any external references among 


Part No. 


07-0086-01 


07-3361-01 


Description 


28 Software Develop- 
ment Package 
Object Cartridge Disk 
for Use with PDS 
8000/20A 


Z8 Software Develop- 
ment Package 
Object Diskette for Use 
with PDS .8000/5 and 
PDS 8000/15 


separately assembled modules. It can 
also reorder and combine named sec- 
tions found in the input assembly 
language modules. ZLINK accepts a 
symbolic specification of 
the program entry point in the com- 
mand line and, on request, produces a 
detailed link map which gives the loca- 
tions of global references and relocated 
modules and sections. Errors in the 
' 


linking process are reported in the 
optional link map and at the system 
console. 


Imager. IMAGER accepts multiple"" 
linked-object files from the linker and 
translates them into absolute code. 
IMAGER can then either store the 
absolute code in a disk file or leave it 
in system memory. Named sections 
found in the input object modules may 
be reordered and loaded anywhere in 
system memory. 


Program Transfer. LOAD/SEND 
downloads an absolute program file 
into the Z8 Development Module for 
debugging, then sends it back to the 
disk for back-up and storage . 


Prom Programming. Z-PROG stores 
the perfected load module in PROM. 


Pent No. 
07-3362-01 


07-3363-01 


Description 
Z8 Software Develop- 
ment Package 
Object Diskette for Use 
with ZDS-1 Series 


Z8 Software Develop- 
ment Package 
Object Cartridge Disk 
for Use with PDS 
8000/20 and PDS 
8000/30 
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Reader's Comments 


Your feedback about this document helps us ascertain your needs and fulfill them in the future. 
Please take the time to fill out this questionnaire and return it to us. This information will bo 
helpful to us and. in time. to future users of Zilog products. 


Your Name: 


Company Name: 


Address: 


Title of this docum~nt: 
Briefly describe application: ______________________________ _ 


Does this publication meet your needs? 0 Yes 0 No 
If no, why? 


How are you using this publication? 
How do you find the material? 
o As an introduction to the subject? 
Excellent 
Good 
Poor 
o As a reference? 
Technically 
D 
0 
0 
o As an instructor or student? 
Organization 
D 
0 
0 


Completeness 
D 
0 
0 


Rated on a scale of 1 to 10. this data book is a ___ _ 


What would have improved the material? ________________________ _ 


Other comments and suggestions: 


If you found any mistakes in this document. please let us know what and where they are: 


After you have filled out this page, please clip it and return to Zilog, Inc., Corporate Communications, 
Building A, 1315 Dell Ave, Campbell, California 95008. 
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